【问题标题】:Keeping a cursor alive in pymongo在 pymongo 中保持光标处于活动状态
【发布时间】:2014-06-18 13:05:54
【问题描述】:

默认情况下,Mongo 游标会在 10 分钟不活动后消失。我有一个空白光标,我最终想通过整个数据库运行,但会有超过 10 分钟的不活动时间。我需要一种方法来保持它的活力,以便我可以继续调用它。

完全关闭到期时间不是一种选择。如果这个程序崩溃,它会导致游标在数据库内存中徘徊,这是不好的。在我做其他事情时偶尔调用 .next() 也不起作用,因为批量大小设置得相当高,以便在代码的其他部分调用游标时获得良好的性能。

我尝试定期调用 cursor.alive 来查看它是否向 Mongo 发送了一个信号,该信号将使光标保持活动状态,但没有奏效。

【问题讨论】:

    标签: mongodb pymongo


    【解决方案1】:

    尝试使用较小的批量。这将导致活动,您不应达到 10 分钟超时。

    for doc in coll.find().batch_size(10):
    

    或者,您可以在调用find 时设置timeout=False(如果未手动关闭光标,这可能会导致问题):

    for doc in coll.find(timeout=False)
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-01-14
      • 1970-01-01
      • 2012-01-03
      • 2014-11-16
      • 2012-05-24
      • 2021-09-13
      • 2018-11-26
      • 2013-08-27
      相关资源
      最近更新 更多