今天tomcat在跑任务时发现每次都有报错java.net.SocketException: Too many open files,
通过查阅文档发现是当时做系统初始化操作时忘了设置ulimit值,以至于一直使用默认值1024。
于是马上修改配置文件
echo "* soft nofile 200000">>/etc/security/limits.confecho "* hard nofile 200000" >>/etc/security/limits.confulimit -SHn 200000 ## 对当前窗口生效,关闭后失效
但是再次跑任务时候发现报错依旧,于是各种查找,最后想到tomcat在修改ulimit后没有重启。重启后问题解决。
查找相关文档发现以下原因:
如果程序A已经运行,此时ulimit -n为1024;
然后设置ulimit -n 2048,这时再运行程序B;
退出当前shell用户,再次登录shell,运行程序C;
这时只有B程序用的是2048,其它用的都是1024.
参考文献:http://www.th7.cn/system/lin/201309/45075.shtml