mina高并发连接导致java.io.IOException: Too many open files解决方法

这几天在实习的公司给一个项目搞测试,主要测试项目部署在Linux Server上的并发访问,即所谓的压力测试;


模拟网关,建立大量并发连接,用的是apache的mina建立的NioSocketConnector();


在多线程的模式下,开启了1000个连接,结果抛出异常“java.io.IOException: Too>


一番尝试,发现还是不行,继续搜索答案...


最终发现问题出在Linux下默认的Socket最大连接数为1024(可以通过ulimit -n查看)。


于是开始修改Linux的配置文件来增加连接数;

#cd /etc/security

vi limits.conf

在文件/etc/security/limits.conf最后加入下面两行:


* soft nofile 30000

* hard nofile 32768


用'*'号表示修改所有用户的限制;

soft或hard指定要修改软限制还是硬限制;30000则指定了想要修改的新的限制值,即最大打开文件数(请注意软限制值要小于或等于硬限制)。修改完后保存文件。


重启Linux,通过ulimit -a查看可以发现

open files                      (-n) 30000


到此,问题得以解决!


你可能感兴趣的:(3.Linux/Unix,1.Java)