PostgreSQL max_connections配置优化

当用户与PostgreSQL建立连接时,先与postmaster进程建立连接,然后postmater fork一个子进程给这个连接。对于创建的每个连接,操作系统都需要为打开网络套接字的进程分配内存,最多扩展到数千个连接后,而只为用户准备使用数据库的阶段就浪费了很多时间。

设置较高max_connections也涉及到其他成本比如磁盘争用,造成过多的io等待;操作系统调度甚至CPU级别的缓存争用。

同时,对于每一个连接,在shared memory中都有一个结构体PGPROC用于追踪正在运行的后端进程和事务

这些是PostgreSQL本身的情况,当连接数上来之后,这些也是可能的瓶颈。同样,连接数上来之后,每个后端进程起始大小大约为5MBÿ

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值