netty服务器启动后,客户端1600多个设备会主动连接上。
查看前几天的日志发现,时不时会有断开连接 关闭连接日志打印出来,也就是会调用netty的channelInactive 和 handlerRemoved 方法

当然也不排除是客户端主动断开的行为,但是直到昨天服务器直接挂掉了。
出现很奇怪的现象,当所有的设备连接上去的时候,过了几分钟就主动把客户端的连接T掉。
在网上查了很多调优方案,但还是解决不了这个问题。服务器用的是阿里云Linux 64位,配置是双核 8G内存 5M带宽。现在就差没把服务器的配置提升了。客户端连接的时候我也监控过CPU和内存的使用都是够的,应该不会1600个socket连接承受不了吧。
已经找这个问题找了一天一夜了,不知道是哪里出了问题。求大神指导思路
增加一些日志,看服务端具体因为什么进行断开,是不是程序异常退出了等
2017-11-02 11:12:23,882 INFO LockServerHandler - [关闭连接]
2017-11-02 11:12:23,882 INFO LockServerHandler - [断开连接]
2017-11-02 11:12:23,882 INFO LockServerHandler - [关闭连接]
2017-11-02 11:12:23,882 INFO LockServerHandler - [断开连接]
2017-11-02 13:04:29,865 INFO LockServerHandler - [连接异常]
java.io.IOException: Connection reset by peer
at sun.nio.ch.FileDispatcher.read0(Native Method)
at sun.nio.ch.SocketDispatcher.read(SocketDispatcher.java:21)
at sun.nio.ch.IOUtil.readIntoNativeBuffer(IOUtil.java:198)
at sun.nio.ch.IOUtil.read(IOUtil.java:166)
at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:245)
at io.netty.buffer.PooledUnsafeDirectByteBuf.setBytes(PooledUnsafeDirectByteBuf.java:259)
at io.netty.buffer.AbstractByteBuf.writeBytes(AbstractByteBuf.java:885)
at io.netty.channel.socket.nio.NioSocketChannel.doReadBytes(NioSocketChannel.java:226)
at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:70)
at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:429)
at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:392)
at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:322)
at io.netty.util.concurrent.SingleThreadEventExecutor$2.run(SingleThreadEventExecutor.java:114)
向客户端发关数据前有没有判断连接的状态
或许是链路断开,查看一下连接状态
对端断开连接了,是不是没有心跳维持连接