前言
最近在公司开发推送系统相关的项目,需要在单台Linux服务器上支持几十万到上百万的连接,为此,修改了操作系统的文件描述符上限。
相关修改操作可参考:
http://jameswxx.iteye.com/blog/2096461
修改并重启后使用ulimit -a查看发现open-file变大。之后,使用netty简单构建一个服务端demo,经测试证明该demo能够支持多于1024个连接(系统初始open-file为1024),修改有效。
但将应用打成war包通过tomcat启动后,最多只能支持略多于5000个连接,查看/proc/${pid}/limits文件,发现文件描述符上限为5000,并未随着系统设置而改变,同时其它JVM进程的文件描述符上限更改已经生效。
网络上众多参考文章没有给出相关的答案,后来google到了这么一篇,明天试试,希望有用:
https://ubuntuforums.org/showthread.php?t=1583041
大意是与守护进程有关,需要采用一些work-around的方法。
具体操作:
1.通过进程pid找到对应的用户名,例如tomcat
2.在/etc/security/limits.d下找到对应用户名conf文件,修改文件描述符大小
3.重启应用,验证生效