共计 600 个字符,预计需要花费 2 分钟才能阅读完成。
今天系统中有一台 Linux 服务器出现异常,有时连简单的 shell 命令都无法执行,各种奇怪的报错,有的时候又可以成功执行
如:
-bash: error while loading shared libraries: libncurses.so.5: cannot open shared object file: Error 23
-bash: /etc/profile: Too many open files in system
查看当前操作系统允许打开的文件数
ulimit -n
发现设置为 163840,执行 lsof|wc -l 命令为 65528,和设定的值还有很大差距,为什么还会报 too many open files 呢,突然想起还有一个地方设置最大文件数
使用命令
cat /proc/sys/fs/file-max
65536, 这个时候知道为啥出现偶发的异常了,当前系统使用的文件数和最大数相隔很近
echo 131072 > /proc/sys/fs/file-max 直接增大一倍,这样可以马上生效,但是如果操作系统重启,又会失效
如果需要永久生效,修改 /etc/sysctl.conf 文件,后面加上 fs.file-max = 131072,执行 sysctl - p 生效
所以当系统中出现 too many open files 时候有 2 个地方都需要看下
问题解决。
本文永久更新链接地址:http://www.linuxidc.com/Linux/2015-12/126516.htm
正文完
星哥玩云-微信公众号