跳转到内容
彼岸论坛
欢迎抵达彼岸 彼岸花开 此处谁在 -彼岸论坛

[问与答] 关于 PostgreSQL 中的 max_connections 和 pg_stat_activity 的疑惑


小天管理

已推荐帖子

问题描述

各位大佬,有个问题请教下 我在本地( 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

我预测的值应该是:

  1. Python 获取到 90 个连接(因为执行 Python 脚本前,就有 10 个连接了,这几个连接可能是开了 Navicat 和 pgAdmin4 的缘故)
  2. pg stat activity 最后应该正好是 100 或者 99 (留一个连接给超级用户?)

但是结果完全不一样,105 明显超过了,这多出来的 5 个是如何得到的?

意见的链接
分享到其他网站

加入讨论

您现在可以发表并稍后注册. 如果您是会员,请现在登录来参与讨论.

游客
回复主题...

×   粘贴为富文本.   粘贴为纯文本来代替

  只允许使用75个表情符号.

×   您的链接已自动嵌入.   显示为链接来代替

×   您之前的内容已恢复.   清除编辑器

×   您无法直接粘贴图片.要从网址上传或插入图片.

  • 游客注册

    游客注册

  • 会员

    没有会员可显示

  • 最新的状态更新

    没有最新的状态更新
  • 最近查看

    • 没有会员查看此页面.
×
×
  • 创建新的...