关于 PostgreSQL 中的 max_connections 和 pg_stat_activity 的疑惑

查看 27|回复 2
作者:Koril   
问题描述
各位大佬,有个问题请教下
我在本地( Windows11 )安装了一个 PostgreSQL ,一切都是默认值安装
我通过以下语句查到 max connections 的值是 100
show max_connections; -- 返回 100
我猜测这个应该就是 PG 默认的最大连接数,然后我用 Python 写了一个脚本,循环获取 connection:
import psycopg2
import time
def get_db_conn():
    conn = psycopg2.connect(host='localhost',port=5432,database='study_demo',user='postgres',password='123456')
    return conn
def main():
    conn_list = list()
    for i in range(100):
        print(f'获取第 {i} 个连接')
        try:
            conn_list.append(get_db_conn())
        except Exception:
            print(f'获取第 {i} 个连接失败')
    print(f'成功获取 {len(conn_list)} 个连接')
    time.sleep(60)
   
if __name__ == '__main__':
    main()
然后代码显示获取到了 95 个连接,然后我通过以下 SQL 获取连接数
select count(*) from pg_stat_activity; -- 返回 105
我预测的值应该是:
[ol]
  • Python 获取到 90 个连接(因为执行 Python 脚本前,就有 10 个连接了,这几个连接可能是开了 Navicat 和 pgAdmin4 的缘故)
  • pg stat activity 最后应该正好是 100 或者 99 (留一个连接给超级用户?)
    [/ol]
    但是结果完全不一样,105 明显超过了,这多出来的 5 个是如何得到的?
  • ampedee   
    pg stat activity 返回结果是连接进程状态的超集,除了会话进程,还有其他辅助进程,你可以看下输出字段加个筛选条件
    XueXianqi   
    应该还有一个地方可以设置类似于 MAX_OVERFLOW 的参数,允许溢出的连接数
    您需要登录后才可以回帖 登录 | 立即注册

    返回顶部