我编写了一个使用
Java NIO API执行非阻塞IO的服务器.我看到一种情况,即偶尔客户端应用程序突然关闭(例如由于断电),并且连接在服务器端保持打开状态.
一位同事遇到了同样的问题,并表示他使用心跳来检测这类事情,但我希望有一种更简单的方法.还有其他人遇到过这个问题吗?
一些附加信息:我的当前服务器设计将取消密钥并在尝试读/写操作时捕获IOException时关闭相应的通道.这种方法似乎在99%的时间内起作用;我只看到了一些连接似乎保持打开的情况.
解决方法
如果没有app级别的心跳,你唯一的选择就是依靠TCP keepalive.但默认间隔很长(比如2小时). RFC不建议间隔短于2小时.
您可以缩短它,但这是一个系统范围的参数.在某些操作系统上,它甚至需要内核重建来改变它.
因此,对于任何基于TCP的协议,强烈建议使用心跳.