使用背景:很多设备联网过程中都会有个设备状态,比如空闲、使用中、离线等,而这些状态的更新,依靠的是心跳机制来完成。与此同时,网络中存在着一些空链接(TCP连接状态中,但没实际通信数据),或是有些设备联网过程中断网,这些链接会占用一部分的服务器资源,那心跳机制也可以帮助服务器剔除一些无效的链接。
还有一个问题:TCP协议中有个心跳机制,私有协议中我们也做了个心跳机制,那这两个机制有什么区别?
在TCP的机制里面,本身是存在有心跳包的机制的,也就是TCP的选项:SO_KEEPALIVE。系统默认是设置的2小时的心跳频率。但是它检查不到机器断电、网线拔出、防火墙这些断线。而且逻辑层处理断线可能也不是那么好处理。一般,如果只是用于保活还是可以的。(引用于https://blog.csdn.net/qq_33314107/article/details/80574137)(检测TCP链路的空闲时间,如果持续空闲了120分钟,那么服务端的TCP协议栈会主动发一个keepalive报文段给客户端,对方没有回复,默认会重传9次,每次重传间隔是75s,9*75s后客户端仍然没响应,服务端会主动关闭该链路。期间,如果距离上一次传输数据后120分钟内又发生了数据传输,那么TCP心跳程序会将自己的定时器重置,反复执行以上流程。)
Netty中也可以设置SO_KEEPALIVE这