PostgreSQL :FATAL: remaining connection slots are reserved for non-replication superuser connections
目录标题
- **PostgreSQL 连接数超限问题解决方案**
- **一、错误原因分析**
- **二、查看连接数与配置**
- **三、排查连接泄漏(应用侧问题)**
- **四、服务侧配置调整**
- **1. 调整最大连接数**
- **2. 释放无效连接(谨慎操作)**
- **3. 使用连接池工具(推荐)**
- **五、长期优化建议**
以下是完整的 PostgreSQL 连接数超限问题解决方案文档:
PostgreSQL 连接数超限问题解决方案
一、错误原因分析
错误 FATAL: remaining connection slots are reserved for non-replication superuser connections 表示:
- PostgreSQL 数据库的连接数已达到 max_connections 限制。
- 剩余连接槽位仅保留给非复制超级用户(如 postgres),普通用户(如 idc)无法建立新连接。
关键机制:
- max_connections:数据库允许的最大连接数(默认值通常为 100)。
- superuser_reserved_connections:为超级用户预留的连接数(默认值为 3)。
- 当普通用户连接数达到 max_connections - superuser_reserved_connections 时,仅超级用户可建立新连接。
二、查看连接数与配置
-
查看最大连接数:
SHOW max_connections; -- 输出当前配置的最大连接数
-
查看当前连接数:
SELECT COUNT(*) FROM pg_stat_activity; -- 统计所有活跃连接数
-
按数据库/用户/客户端地址分组统计:
SELECT datname AS "数据库", usename AS "用户", client_addr AS "客户端地址", COUNT(*) AS "连接数" FROM pg_stat_activity GROUP BY datname, usename, client_addr ORDER BY COUNT(*) DESC;
-
查看特定用户的查询会话:
SELECT datname, usename, query FROM pg_stat_activity WHERE usename = '目标用户名'; -- 替换为实际用户名
三、排查连接泄漏(应用侧问题)
-
检查代码逻辑:
- 确保数据库连接在使用后正确关闭(如 Java 中使用 finally 块):
Connection conn = null; try { conn = DriverManager.getConnection(url, username, password); // 执行数据库操作 } catch (SQLException e) { // 异常处理 } finally { if (conn != null && !conn.isClosed()) { conn.close(); // 确保连接关闭 } }
-
引入连接池:
- 使用连接池(如 HikariCP、PGBouncer)管理连接,避免无限制创建新连接:
jdbc:postgresql://localhost:5432/mydb idc password 50
- 使用连接池(如 HikariCP、PGBouncer)管理连接,避免无限制创建新连接:
- 确保数据库连接在使用后正确关闭(如 Java 中使用 finally 块):
四、服务侧配置调整
1. 调整最大连接数
步骤:
-
编辑配置文件:
vi /etc/postgresql/版本号/main/postgresql.conf
- 找到 max_connections = 100,修改为:
max_connections = 200 # 根据服务器内存调整(每连接约消耗 10MB+ 内存)
-
重启数据库:
sudo systemctl restart postgresql
- 找到 max_connections = 100,修改为:
注意事项:
- 需根据服务器内存调整,公式参考:max_connections = 总内存 / 每连接内存占用(如 8GB 内存建议不超过 500)。
- 重启会中断所有连接,建议在低峰期操作。
2. 释放无效连接(谨慎操作)
超级用户权限执行:
-- 终止所有非活跃连接(谨慎操作,避免影响业务) SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE state = 'idle' AND pid != pg_backend_pid();
3. 使用连接池工具(推荐)
推荐工具:
- PGBouncer:轻量级连接池,适合高并发场景。
# 安装(Ubuntu 示例) sudo apt-get install pgbouncer
- 配置文件:
[databases] mydb = host=localhost port=5432 dbname=mydb user=idc password=password [pgbouncer] listen_port = 6432 max_client_conn = 100 # 客户端最大连接数 pool_size = 20 # 数据库后端连接池大小
- 启动服务:
sudo systemctl start pgbouncer
五、长期优化建议
-
监控连接数:
-- 定期执行以下查询,监控连接数趋势 SELECT datname, COUNT(*) AS "连接数", NOW() AS "时间" FROM pg_stat_activity GROUP BY datname ORDER BY COUNT(*) DESC;
-
限制用户连接数:
-- 为特定用户设置连接上限 ALTER ROLE idc WITH CONNECTION LIMIT 50;
- 业务逻辑优化:
- 减少长事务,避免事务阻塞连接。
- 使用异步查询或批量操作减少连接占用。
通过以上步骤,可有效解决 PostgreSQL 连接数超限问题,并建立长期监控机制防止复发。
-
- 配置文件:
- PGBouncer:轻量级连接池,适合高并发场景。
-
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。