各位大佬,有个问题请教下 我在本地( 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
我预测的值应该是:
但是结果完全不一样,105 明显超过了,这多出来的 5 个是如何得到的?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.