最新项目服务器框架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 数值也恢复正常

Logo

更多推荐