netty "too many open files" 解决方案
最新项目服务器框架netty报错,too many open files在linux系统使用命令行netstat -ant | grep ":30003" | awk '{print $6}' | sort | uniq -c | sort -nr打印出 70092 ESTABLISHED 1 LISTEN 1 LAST_ACK
最新项目服务器框架netty报错,too many open files
在linux系统使用命令行
netstat -ant | grep ":30003" | awk '{print $6}' | sort | uniq -c | sort -nr
打印出
70092 ESTABLISHED
1 LISTEN
1 LAST_ACK
发现服务器连接中,已经有超过7万的连接。根本不可能啊。因为我们根本没那么多用户好不好!
在网上搜查资料的时候,发现我们用的netty版本是3.X的,网上很多解决方案是NETTY4。
网上查阅jboss文档(http://www.boyunjian.com/javadoc/org.jboss.netty/netty/3.2.9.Final/_/org/jboss/netty/handler/timeout/IdleStateAwareChannelHandler.html)
最终的解决方案是使用 IdleStateHandler 类来进行每个通道的超时监听与处理。
具体用法在上述文档也有,发个截图上来
测试结果异常断开的TCP连接会根据自身设置的时候由服务器发起close请求关闭。
ESTABLISHED 数值也恢复正常
更多推荐
所有评论(0)