postgresql出错could not create semaphores: No space left on device

Posted 明矾

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了postgresql出错could not create semaphores: No space left on device相关的知识,希望对你有一定的参考价值。

在postgres中,当max_connect设置过大,启动的时候会报错:

FATAL:  could not create semaphores: No space left on device

创建semaphores时空间参数不够,查询官网,有这么一段解释:

HINT:  This error does *not* mean that you have run out of disk space.  It occurs when either the system limit for the maximum number of semaphore sets (SEMMNI), or the system wide maximum number of semaphores (SEMMNS), would be exceeded.  You need to raise the respective kernel parameter.  Alternatively, reduce PostgreSQL\'s consumption of semaphores by reducing its max_connections parameter.
The PostgreSQL documentation contains more information about configuring your system for PostgreSQL.
解决的方法是改小max_connect,当业务不允许的情况下,修改内核参数,max_connect相关的内核参数有:

 

 下面介绍如何修改内核参数

# ipcs -ls
 
------ Semaphore Limits --------
max number of arrays = 1280
max semaphores per array = 50100
max semaphores system wide = 64128000
max ops per semop call = 50100
semaphore max value = 32767
 
 
# cat  /proc/sys/kernel/sem
SEMMSL   SEMMNS         SEMOPM  SEMMNI
50100   128256000       50100   2560
SEMMSL 每个信号量set中信号量最大个数
SEMMNS linux系统中信号量最大个数
SEMOPM semop系统调用允许的信号量最大个数设置,设置成和SEMMSL一样即可
SEMMNI  linux系统信号量set最大个数
 
所以SEMMNS=SEMMSL*SEMMNI
修改 vi /etc/sysctl.conf 的以下参数
kernel.sem = 50100 128256000 50100 2560
sysctl -p生效
重启数据库即可

以上是关于postgresql出错could not create semaphores: No space left on device的主要内容,如果未能解决你的问题,请参考以下文章

postgresql 日志报错could not write to log file: No space left on device,could not write lock file "

PostgreSQL pg_rewind实例--could not find previous WA

The application server could not be contacted

PostgreSQL - ERROR: could not determine data type of parameter $1

Cordova使用build命令出错: Could not create the Java Virtual Machine.

Ubuntu 14.04 安装 VMware Player出错: Could not open /dev/vmmon:?