当前位置:Gxlcms > 数据库问题 > PostgreSQL--信号量和shmall 和 shmmax相关设置

PostgreSQL--信号量和shmall 和 shmmax相关设置

时间:2021-07-01 10:21:17 帮助过:16人阅读

二、max_connections与信号量的关系

如果max_connections设置太大,信号量被消耗完毕,有可能会导致PostgreSQL无法启动

2.1、信号量设置

信号量控制设置在/etc/sysctl.conf文件中,通过sysctl -p 可以生效,该文件用于控制内核信号量,信号量是System VIPC用于进程间通讯的方法。

kernel.sem = 250 512000 100 2048

 

2.2、查询当前信号量使用情况

查看当前信号量使用情况
技术图片
 

2.3、查看当前的设置:

cat /proc/sys/kernel/sem
技术图片
这四个数字分别是:SEMMSL,SEMMNS,SEMOPM,SEMMNI
SEMMSL:内核参数,控制每个信号量集合的最大信号数。
SEMMNS:内核参数,控制系统范围内能使用的最大信号量数。
SEMOPM:semop()函数(内核函数,用来操作信号量)每次调用锁能操作的一个信号量集中的最大信号量。
SEMMNI:内核中信号量集的最大数量。
SEMMNS=SEMMSL*SEMMNI
SEMOPM=SEMMSL,这两个参数一般设置为相同。
 

2.4、信号量设置计算

对于PostgreSQL数据库来说:
SEMMNI >= ceil((max_connections + autovacuum_max_workers + 4) / 16)
SEMMSL >= 17
假设一个PG库如下设置:
max_connections=1000, autovacuum_max_workers =3,
则这几个参数的设置是:
SEMMNI = ceil((1000+3+4))/16)=63,因为考虑到其他进程使用,一般设置为63+25=88
SEMMSL要求大于17,保持默认250
SEMOPM=SEMSL=250
SEMMNS=SEMMNIMSMMSL=88250=22000
在/etc/sysctl.conf文件中添加:

kernel.sem=250  22000 250  88
运行:sysctl -p   生效 

使配置生效
设置完成之后,如果启动数据库还是报同样的错误,那么可以重启操作系统再试试。

PostgreSQL--信号量和shmall 和 shmmax相关设置

标签:sga   集合   system   mic   使用   函数   png   div   内核   

人气教程排行