postgres标准全称PostgreSQL,通常指其命令行客户端
1. 核心限制参数
PostgreSQL 的连接数限制主要由配置文件
postgresql.conf 中的 max_connections 参数决定。- 默认值:通常为
100。 - 理论上限:受操作系统资源(如文件描述符限制
ulimit)和内存大小限制。通常建议通过 连接池(如 PgBouncer) 来处理成千上万的并发请求,而不是直接调大该参数。
2. 如何查询当前端口和连接限制
你可以通过 SQL 命令行工具(如
psql)执行以下指令来获取 2025 年生产环境下的实时配置:A. 查看最大连接数限制
sql
SHOW max_connections;
Use code with caution.
B. 查看当前已使用的连接数
sql
SELECT count(*) FROM pg_stat_activity;
Use code with caution.
C. 查看服务监听的端口
sql
SHOW port;
Use code with caution.
D. 获取详细的连接槽位信息(按用户/数据库统计)
sql
SELECT datname, usename, count(*)
FROM pg_stat_activity
GROUP BY datname, usename;
Use code with caution.
3. 操作系统层面的限制
即便 PostgreSQL 设置了很高的
max_connections,如果操作系统层面的端口范围或文件句柄不足,也会导致连接失败。- 可用端口范围(针对客户端连接):
在 Linux 上查看:cat /proc/sys/net/ipv4/ip_local_port_range - 最大文件打开数:
查看当前进程限制:ulimit -n
4. 如何修改限制
若需增加连接上限,请遵循以下步骤:
- 找到配置文件:
SHOW config_file;。 - 修改
max_connections = 500(根据服务器内存调整,每个连接约占用 10MB 左右内存)。 - 必须重启服务 才能生效:
sudo systemctl restart postgresql。
提示:如果你的并发需求超过 500-1000,强烈建议在应用和数据库之间部署 PgBouncer。它能显著降低端口压力并提高资源利用率。你可以通过 PostgreSQL 官方文档 了解更多性能调优细节。