zoukankan      html  css  js  c++  java
  • 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生效
    重启数据库即可
    但行好事,莫问前程
  • 相关阅读:
    解决ie下vue列表数据不能即时刷新的问题
    redis的几个知识点
    oracle查找某个字符在字符串中的个数的技巧
    程序员必看书籍
    eclipse彻底去除validation(彻底解决编辑js文件的卡顿问题)
    eclipse强行停止buliding workspace
    [Ljava.lang.String是一个字符串数组的字节码表示
    javascript合并两个数组
    css隐藏页面元素的方法
    配置IIS使用Python
  • 原文地址:https://www.cnblogs.com/qiumingcheng/p/15209496.html
Copyright © 2011-2022 走看看