前端之家收集整理的这篇文章主要介绍了
PostgreSQL错误:由于与恢复冲突,取消语句,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当在备用模式下在Postgre
sql数据库上运行
查询时,我收到以下
错误。导致
错误的
查询在1个月内正常工作,但是当您
查询超过1个月时,会出现
错误。
ERROR: canceling statement due to conflict with recovery
Detail: User query might have needed to see row versions that must be removed
有关如何解决的任何建议?谢谢
在热备服务器上运行
查询有点棘手 – 它可能会失败,因为在
查询期间,一些需要的行可能会在主服务器上更新或
删除。作为主要不知道
查询在辅助节点上启动,它认为它可以清理(真空)其行的旧版本。然后secondary必须重放这个清理,并且必须强制取消可以使用这些行的所有
查询。
较长的查询会更频繁地取消。
您可以解决这个问题通过启动一个可重复读事务在主要进行虚拟查询,然后坐在空闲,而真正的查询运行在次要。它的存在将防止旧行版本的初级真空吸尘器。
有关此主题和其他解决方法的更多信息,请参阅文档中的@L_403_0@部分。