我有一个 MongoDB 集合(用作作业队列),多个进程从中读取记录,使用findAndModify
. FindAndModify
搜索active
字段为“false”的记录,将其设置为“true”,这样其他进程就不会读取相同的记录。
问题是查看日志,我看到不同的进程仍然读取相同的记录。这似乎发生在两个进程同时从队列中读取时。有什么方法可以确保一次只处理从集合中读取的内容?
我正在使用 Mongo 2.2.3 和 pymongo 2.2。
非常感谢!
编辑:有问题的日志是:
worker.3 2013-03-18 23:57:45,434 default-worker-3
project_name INFO 队列作业:作业 ID:5147a90f68e8fe0097002bdfworker.3 2013-03-18 23:57:47,608 default-worker-3
project_name INFO 输入:14497 文档worker.2 2013-03-18 23:57:45,440 default-worker-2
project_name INFO 队列作业:作业 ID:5147a90f68e8fe0097002bdfworker.2 2013-03-18 23:57:47,658 default-worker-2
project_name INFO 输入:14497 文档
如您所见,worker.3 和worker.2 从队列中读取相同的作业(两个worker 具有相同的mongodb id)。
find_and_modify 命令:
query = {"active": False}
try:
return self.collection.find_and_modify(
query=query,
update={"$set": {"active": True}},
upsert=False,
sort={"added_on": 1},
limit=1
)
except Exception, exc:
LOGGER.exception(exc)