在MongoDB操作中,先从数据库中取得所有数据 db.find({}),然后对数据进行for循环
demo = db['demo'].find({})
for cursor in demo:
do_something()
但是当do_something里面的内容耗时过长,在cursor上长时间没有进行操作,会引发cursor在mongodb服务端超时 pymongo.errors.CursorNotFound: Cursor not found 错误。
解决方法
第一种:设置no_cursor_timeout = True,永不超时,游标连接不会主动关闭,需要手动关闭
demo = db['demo'].find({},no_cursor_timeout = True)
for cursor in demo:
do_something()
demo.close() # 关闭游标
第二种 : 设置batch_size返回文档数,默认是20个文档,可以设置小一些,尽量让他能执行完。
demos = db['demo'].find({}).batch_size(1)
for cursor in demo:
do_something()
# 只返回一个文档