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"
from looking into the code i see a select like that: @selector={"_id"=>{"$oid"=>"[some id]"}}
what can get wrong here?
可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
回答1:
adding this to my gemfile
fixed the issue:
gem 'multi_json', '1.5.1'
i guess something is wrong with the latest version (1.6.0)
EDIT: the gem has been updated to new version (1.6.1) that fixed this issue. more here: https://github.com/intridea/multi_json/issues/89
回答2:
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)