欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

pymongo.errors.CursorNotFound: Cursor not found

程序员文章站 2024-02-10 13:56:34
...

在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()

#   只返回一个文档
注意这两种方法可能也会因为 do_something()里面的操作太过消耗时间,出现超时的错误,所以建议两者一同使用,根据具体情况而定。
相关标签: MongoDB操作