failed with error 10068: “invalid operator: $oid”

后端 未结 2 1859
小蘑菇
小蘑菇 2020-12-20 15:05

just updated to the latest version of mongoid (3.1.0) and sidekiq (2.7.2)
now i\'m getting the error : failed with error 10068: \"invalid operator: $oid\"

2条回答
  •  囚心锁ツ
    2020-12-20 15:40

    This is actually happening because BSON::ObjectId is not part of JSON... so when Sidekiq tries to serialize the args to the worker, it pukes. Check out this comment: https://github.com/mperham/sidekiq/issues/951#issuecomment-19497803

    The fix is simply to convert IDs to strings when performing a job like:

    EmailSubscribe.perform_async(user.id.to_s)
    

提交回复
热议问题