并发量高会报错:java.io.IOException: Too many open files

用 CentOS 做 API 接口服务器供其他终端调用时,并发量高会报错:java.io.IOException: Too many open files。

其原因是在 Linux 下默认的Socket最大连接数为 1024(可以通过 ulimit -n 查看)

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

1.在/etc/rc.local 后增加一行

ulimit -SHn 65535

2.在/etc/profile 后增加一行 

ulimit -SHn 65535

3.在/etc/security/limits.conf最后加入两行

* soft nofile 65535

* hard nofile 65535

如果问题还未解决则有可能是程序中有些资源链接打开一直未关闭则需要进一步查看找到问题所在

查看当前系统打开的文件数量

lsof | wc -l
watch "lsof | wc -l"

查看某一进程的打开文件数量
lsof -p pid | wc -l
lsof -p 1234 | wc -l




找到句柄数量最多的进程id  查看 lsof -p 25397 





发现很多链接一直未关闭。则定位到代码中发起请求未关闭流导致问题,修改后解决问题

发布了42 篇原创文章 · 获赞 4 · 访问量 1万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章