• SUSE Linux 报错:too many open files in system


    

    现网执行的oracle数据库,有一天突然报错(alert日志):too many open files in system,须要对操作系统同意句柄数进行扩充,查阅了非常多资料,改动点主要集中在例如以下几个文件:

    1./proc/sys/fs/file-max

    2./etc/sysctl.conf

    3./etc/security/limits.conf

    还有通过命令改动的方法,如ulimit -n 65535


    以下以我实际的经验说一下,我改动的是/etc/security/limits.conf,

    oracle soft nofile 2048 
    oracle hard nofile 32768 
    oracle soft nproc 2048 
    oracle hard nproc 32768 

    以下重点说明一下上面这些值是什么含义:
    1.第一个字段是对指定用户的限制,假设改为星号,则表示对不论什么用户都适用
    2.第二个字段。soft是软限制,hard时硬限制。这么说。太难懂了。实际是什么意思呢? 在oracle用户下。你能够通过命令去改动自己限制,可是这个限制值不能超过hard相应的值。而你假设不改的话,那默认的限制就是soft相应的值。(能够通过ulimit -n 等方式改动)
    3.nofile 是限制单个进程能够使用的句柄数,通过lsof能够查看某个用户指定进程使用的句柄数,通过实际情况来看,lsof查看到进程使用的句柄数要达到nofile 相应值得一倍,详细他们之间是什么关系,没有弄清楚。
    4.nproc是限制用户能够启动的进程数,实际測试来看。通过ps命令查看到的进程数要小于配置的值。

    总而言之。通过上面的配置,能够改变对进程可使用句柄数、可启动的进程数做到限制。

    /etc/security/limits.conf文件介绍资料:http://hi.baidu.com/linuxtrip/item/cea1f3cf6a11c601c710b2b3

  • 相关阅读:
    SQL-Duplicate Emails
    c#创建可比较对象
    c#扩展方法
    C#Lambda和委托
    C#集合
    c#显示实现接口和隐式实现的区别
    bs同时上传文件以及文件信息
    sql查询数据库中所有 ,数据为空的表
    sql查询所有表名和描述
    MES数据采集模块小结
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5169705.html
Copyright © 2020-2023  润新知