小天管理 发表于 2024年9月13日 发表于 2024年9月13日 问题描述 各位大佬,有个问题请教下 我在本地( 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 我预测的值应该是: Python 获取到 90 个连接(因为执行 Python 脚本前,就有 10 个连接了,这几个连接可能是开了 Navicat 和 pgAdmin4 的缘故) pg stat activity 最后应该正好是 100 或者 99 (留一个连接给超级用户?) 但是结果完全不一样,105 明显超过了,这多出来的 5 个是如何得到的?
已推荐帖子