# 为什么需要心跳检测? (待定,还没想好)
* * * * *
正常的情况客户端断开连接会向服务端发送一个fin包,服务端收到fin包后得知客户端连接断开,则立刻触发事件回调。
但是有些极端情况如客户端掉电、网络关闭、拔网线、路由故障等,这些情况客户端无法发送fin包给服务端,服务端便无法知道连接已经断开。如果客户端与服务端定时有心跳数据传输,则会比较及时的发现连接断开,触发事件回调。
另外路由节点防火墙会关闭长时间不通讯的socket连接,导致socket长连接断开。所以需要客户端与服务端定时发送心跳数据保持连接不被断开。
# 心跳检测的原理是什么?
* * * * *
服务端向客户端(或者客户端向服务器)发送心跳检测,客户端(服务端)接收到心跳数据后,可以忽略不做任何处理,也可以回应心跳检测(向服务端(客户端)发送一段任意数据)。这就分为两种情况,
1、当服务端不要求客户端必须回应心跳检测时,假如客户端遇到掉电等极端情况,这时服务端向客户端发送的心跳数据在TCP层面就会发送超时,遇到这种超时情况TCP会重试多次(次数及间隔依赖操作系统的配置),多次无果后会断开连接。这种极端情况从连接断开到服务端检测到可能要持续至少10分钟才触发事件回调。
2、当服务端要求必须回应检测时,如果服务端在规定的时间内没有收到客户端的任何数据,则立刻判定客户端已经断开,服务端就立即断开连接触发事件回调。
## 心跳包发送格式
* * * * *
| 功能 | 帧头 | 长度 | 网关地址 | 模块地址 | 数据 |
| --- | --- | --- | --- | --- | --- |
| 心跳包 | 0x55 | 0x02 | 0x00000000 | 0x00000000 | 0x20 |