事前准备
下载Wireshark并安装
打开Wireshark,修改过滤规则:ip.src eq 192.168.3.201 or ip.dst eq 192.168.3.201 如图:
不使用KeepAlive
网上有段代码,可以对socket进行心跳检测,下面贴出部分代码:
bool blockingState = socket.Blocking; try { byte[] tmp = new byte[1]; socket.Blocking = false; socket.Send(tmp, 0, 0); return true; }
Socket.Send方法的第二个参数表示发送数据的大小。如果此时设置为0,即使网络正常的情况下也不会发送数据,拔不拔网线无所谓了。
我在心跳的地方记了日志,一直在写,但是WireShark监测不到有消息发送,主要是因为发送数据的大小是0。图:
但当我把第二个参数改成tmp.Length的时候(也就是1),就可以发送数据了。图:
我设置的是每隔7秒发送一次数据。
如果拔掉网线,当下次心跳检测的时候,就会报错。图:
最后一条红色的数据之后,就没有再见到有数据发送了。虽然这种方法可以检测Socket是否断开,但是不是很好,响应不及时。
使用KeepAlive
正常情况
WireShark会检测到不停的往Socket服务器发送消息,也就是心跳检测,图:
三次握手建立连接之后(前三条),每隔3秒心跳检测一次,跟我在代码里面设置的一致。
在拔掉网线的情况下
WireShark监控到每隔1秒发送一次消息,检测10次后发送[RST]命令断开连接。注意看Time列,从16开始执行10次。这是win10系统默认设置。图:
参考网址:https://blog.csdn.net/elie_yang/article/details/95197181