今天系统中有一台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个地方都需要看下