pg_dump: [archiver (db)] query failed: ERROR: out of shared memory HINT: You might need to increas

Posted 離人譖挽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pg_dump: [archiver (db)] query failed: ERROR: out of shared memory HINT: You might need to increas相关的知识,希望对你有一定的参考价值。

问题描述

在使用postgres执行一个存储过程,存储过程的操作是对全库上百张表添加字段,执行到一半的时候抛出了错误:You might need to increase max_locks_per_transaction。

原因

因为一个过程中操作的表过多,超过了最大对象锁的限制数量,导致了异常。

大意是开启事务后,每次操作一张表,会进行一次表级的lock操作,并增加lock的大小,当lock的大小超过了默认的限定值,就会抛出异常。

postgres中默认max_locks_per_transaction大小是64

官方对此的解释

共享锁表跟踪在max_locks_per_transaction * (max_connections + max_prepared_transactions) 个对象(如表)上的锁。
因此,在任何一个时刻,只有不超过这么多个可区分对象能够被锁住。这个参数控制为每个事务分配的对象锁的平均数量。
个体事务可以锁住更多对象,数量可以和锁表中能容纳的所有事务的锁一样多。这不是能被锁住的行数,那个值是没有限制的。
默认值 64 已经被历史证明是足够的,但是如果你有需要在一个事务中使用很多不同表的查询(例如查询一个有很多子表的父表),你可能需要提高这个值。这个参数只能在服务器启动时设置。

当运行一个后备服务器时,你必须设置这个参数为大于等于主服务器上的值。否则,后备服务器上将不允许查询。

解决方案

1、修改配置文件,../data/postgresql.conf,将参数重新配置:max_locks_per_transaction = 1024,然后重启数据库即可

2、减少过程中操作表的数量,即将一个大的存储过程拆分成若干小过程,再进行执行,最终我们采用的是这个方法,因为根据官方的描述,默认配置是经过验证最合理的配置,将配置调大可能会产生未知的风险
————————————————

参考链接:https://blog.csdn.net/wtopps/article/details/78554796

     http://www.postgres.cn/docs/9.5/runtime-config-locks.html

以上是关于pg_dump: [archiver (db)] query failed: ERROR: out of shared memory HINT: You might need to increas的主要内容,如果未能解决你的问题,请参考以下文章

使用pg_dump导出postgres db不起作用,数据库“db_name”不存在

pg_dump 错误:不支持“仅关系”

如何将密码传递给pg_dump?

pg_dump:如何在 Amazon Linux 上安装 PostgreSQL 9.5.2?

pg_dump备份数据结构及数据

PostgreSQL 数据库备份