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

青春壹個敷衍的年華 提交于 2019-11-28 07:21:39

问题


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)


来源:https://stackoverflow.com/questions/14868716/failed-with-error-10068-invalid-operator-oid

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!