java.net.SocketException:Too man
作者:
土卫十六 | 来源:发表于
2017-12-27 11:30 被阅读0次
- 此问题并不能单纯的咱照网上大部分的解决方案如:修改linux系统默认的打开文件数上线 ulimit -n 或修改 /etc/security/limits.conf 文件来解决,这样即便更改了最大文件打开数,当打开文件的数目再次达到设置的数目时,项目依然会崩溃,根本问题还是要解决大量僵尸连接的问题
- netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}' 查看网络连接各状态下的数目,发现CLOSE_WAIT状态数目非常大
- lsof -i :80 (80是端口号),结果中第二列对应的是PID, 确实发现大量进程处于CLOSE_WAIT状态,会发现某个PID对应大量CLOSE_WAIT进程
- ll /proc/{PID } ({PID}填写有问题的PID) 查看到具体某个项目,然后发现此项目中大量使用httpclient请求外部资源
- 查看代码发现httpclient请求的工具类没有设置HttpConnectionManager连接池的参数,而且没有关闭连接,导致所有非200状态连接(即A请求B时,B不存在该资源,B向A发起关闭请求,A被动关闭连接,如果此时A被动关闭之后没有释放连接的话,造成CLOSE_WAIT状态)都会处于CLOSE_WAIT状态
- 接下来就是需要修改代码,手动关闭连接释放资源
本文标题:java.net.SocketException:Too man
本文链接:https://www.haomeiwen.com/subject/xvzygxtx.html
网友评论