因为TCP协议中的SO_KEEPALIVE有几个致命的缺陷:

  1. keepalive只能检测连接是否存活,不能检测连接是否可用。比如服务器因为负载过高导致无法响应请求但是连接仍然存在,此时keepalive无法判断连接是否可用。
  2. 如果TCP连接中的另一方因为停电突然断网,我们并不知道连接断开,此时发送数据失败会进行重传,由于重传包的优先级要高于keepalive的数据包,因此keepalive的数据包无法发送出去。只有在长时间的重传失败之后我们才能判断此连接断开了。


TCP中已有SO_KEEPALIVE选项,为什么还要在应用层加入心跳包机制??

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-09-11
  • 2021-06-17
  • 2022-12-23
  • 2022-12-23
  • 2021-06-24
  • 2021-06-13
猜你喜欢
  • 2021-11-01
  • 2021-11-27
  • 2022-12-23
  • 2021-07-21
  • 2021-06-23
  • 2021-07-21
  • 2021-08-03
相关资源
相似解决方案