IM为什么需要心跳

客户端需要心跳的原因

对于客户端而言,使用 TCP 长连接来实现业务的最大驱动力在于:

在当前连接可用的情况下,每一次请求都只是简单的数据发送和接受,免去了 DNS 解析,

连接建立等时间,大大加快了请求的速度,同时也有利于接受服务器的实时消息。

但前提是连接可用。

NAT

大部分移动无线网络运营商都在链路一段时间没有数据通讯时,

会淘汰 NAT 表中的对应项,造成链路中断(NAT超时的更多描述见附录A)

NAT超时是影响TCP连接寿命的一个重要因素(尤其是国内),

所以客户端自动测算NAT超时时间,来动态调整心跳间隔,是一个重要的优化点


为什么不用tcp的KeepAlive

KeepAlive 并不适用于检测双方存活的场景,

这种场景还得依赖于应用层的心跳。应用层心跳有着更大的灵活性,

可以控制检测时机,间隔和处理流程,甚至可以在心跳包上附带额外信息。

从这个角度而言,应用层的心跳的确是最佳实践。


什么是智能心跳?

智能心跳实际上就是动态的探测到最大的NAT超时时间,

然后选定合适的心跳间隔区间去发送心跳包,同时在网络状况发生变化的时候能够动态的

调整心跳间隔时间;如果心跳间隔不合适,例如心跳间隔过短,

那么可能导致频繁的唤醒手机发送心跳包,增加耗电,心跳间隔过长,

可能导致这条TCP连接已经无效但是无法及时的检测到,

只能等待下一个心跳包发送的时候才能感知到



alarm的对齐唤醒:    6.0时间对不上有延迟

jobservice 进程保活  为不是不支持 6.0杀的进程组,

保活是怎么做的

https://blog.csdn.net/xx326664162/article/details/51611625

https://blog.csdn.net/lhd201006/article/details/52702178

你可能感兴趣的:(IM为什么需要心跳)