pymongo.errors.CursorNotFound: cursor id 1598856597812 not found原因以及解决方式

代码日常运行都没问题突然报错如下

pymongo.errors.CursorNotFound: cursor id 1598856597812 not found

根据异常找到报错位置如下

 def initMaterialOrgAll(self):
        materialAndEnterpriseIdList = formmongodbUtil.findAll(
            "form_ins_d0fd94e7-df33-4e04-b020-24bedcf10a57"
        )
        self.handleMaterialOrg(materialAndEnterpriseIdList)

    def handleMaterialOrg(self, materialAndEnterpriseIdList):
        global ogIdColl
        returnMaterialOrgIdInfo_List = []
        for materialAndEnterpriseIdDic in materialAndEnterpriseIdList://报错行
            //处理代码逻辑省略

 在循环pymongo的cursor时候就报错,在本地运行里面又是有数据的但是为何报错。

经过查证默认 mongo server维护连接的时间窗口是十分钟

  默认 单次从 server获取数据是101条或者 大于1M小于16M的数据

  所以默认情况下,如果10分钟内未能处理完数据,则抛出该异常

刚好这次数据量比较大比平时处理慢,可能是这个问题导致

解决方案:

    def findAll(self, collName):
        result = None
        try:
             result = self.getCollection(collName).find(no_cursor_timeout = True)//此处增加no_cursor_timeout = True 永不超时,游标连接不会主动关闭,需要手动关闭
        except BaseException as e:
             self.logger.error(e)
        return result

处理完后需要手动关闭游标,我这里是materialAndEnterpriseIdList.close()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值