当前位置: 首页 > news >正文

为什么主动关闭 TCP 连接的一方需要 TIME_WAIT 状态?

文章目录

  • 原因 1
  • 原因 2
  • 遗留问题
    • 问题 1
    • 问题 2
  • 为什么 TIME_WAIT 状态的持续时长是 2MSL?

主动关闭 TCP 连接的一方才有 TIME_WAIT 状态

需要 TIME_WAIT 状态,主要有两方面原因:

  1. 防止历史连接的报文(延迟的重传报文)被后面相同四元组的连接错误接收
  2. 保证「被动关闭连接」的一方,能收到对方的 ACK,也就是第四次挥手报文,正常关闭连接

原因 1

TIME_WAIT 状态持续时长 2MSL,这个时间足以让两个方向上的报文都被丢弃,使得原来连接的报文在网络中都自然消失,再出现的报文一定都是新建立的连接所产生的

原因 2

在这里插入图片描述
被动关闭连接的一方收到 RST 报文后,将其解释为一个错误(Connection reset by peer),这对于一个可靠的协议来说不是一种优雅的终止方式
在这里插入图片描述

遗留问题

RFC 1122 4.2.3.1(P96) 规定,RTO_MAX 应该小于等于 2MSL
The recommended upper and lower bounds on the RTO are known to be inadequate on large internets. The lower bound SHOULD be measured in fractions of a second (to accommodate high speed LANs) and the upper bound should be 2*MSL, i.e., 240 seconds.

问题 1

Linux 实现中,RTO_MAX > 2MSL

/* Linux Kernel 6.14.7 tcp.h */
#define TCP_RTO_MAX	((unsigned)(120*HZ))
#define TCP_FIN_TIMEOUT	TCP_TIMEWAIT_LEN/* BSD style FIN_WAIT2 deadlock breaker.* It used to be 3min, new value is 60sec,* to combine FIN-WAIT-2 timeout with* TIME-WAIT timer.*/

假设一种情况,TCP 第四次挥手报文一直丢失,那么就需要反复重传(受 tcp_orphan_retries 限制)第三次挥手报文,如果其中某一次的重传报文需要等待 120s 才被发送出去,但此时对方早已退出 TIME_WAIT 处于 CLOSED 状态,与原因 1 相违背

问题 2

如果 RTO_MAX 范围是 (MSL, 2MSL],假设一种情况,TCP 第四次挥手报文一直丢失,那么就需要反复重传(受 tcp_orphan_retries 限制)第三次挥手报文,如果其中某一次的重传报文需要等待 RTO_MAX(1.01MSL) 才被发送出去,刚好此次重传报文在网络中经过 MSL 时间才到达对端,但此时对方早已退出 TIME_WAIT 处于 CLOSED 状态,与原因 1 相违背

希望有大佬看到后帮忙解答
希望有大佬看到后帮忙解答
希望有大佬看到后帮忙解答

为什么 TIME_WAIT 状态的持续时长是 2MSL?

为什么 TIME_WAIT 状态的持续时长是 2MSL?

相关文章:

  • 使用Haporxy搭建Web群集
  • 嵌入Linux快速入门第3篇
  • JavaEE->多线程2
  • 【Bluedroid】蓝牙启动之 btif_init_ok 流程源码解析
  • 小智AI玩具市场爆发:四大品牌领跑情感交互新赛道
  • 3DTiles三维模型
  • Linux 核心知识点整理(高频考点版)
  • Mac电脑 Office 2024 LTSC 长期支持版(Excel、Word、PPT)
  • 《超级处理器》怎么安装到WPS/excel(最后有下载地址)
  • 李宏毅《生成式人工智能导论》| 第1讲:什么是生成式人工智能
  • 一体机主板步入大存储时代,存储突围到性能质变
  • OpenAI 公布《走向理解与预防失准泛化:由“角色特征”驱动的突现性失准》研究总结
  • MySql升级安装、socket 及密码重置
  • 3.1 Hector_mapping初体验
  • langchain框架中各种Agent(LLMSingleAgent ReactAgent Plan-and-Execute Agent)原理方式对比
  • Spring Boot 虚拟线程 vs WebFlux:谁更胜一筹?
  • Ascend上如何进行带宽测试
  • Spring Boot + MyBatis + Vue:构建高效全栈应用的实战指南
  • px4仿真使用fastlio的定位数据飞行
  • 用流行民族戏腔三种方式打开国风爆款《闲人填梦》,邓超予的跨界演绎引领文化传播新高度!
  • 做网站设计制作的/百度浏览器
  • 网站建设公司业务员/百度搜索关键词统计
  • wordpress仿今日头条/seo搜索优化邵阳
  • 优科技网站建设/买外链
  • 企业网站推广短平快/怎样推广产品
  • wordpress自定义文章类型分类获取/杭州云优化信息技术有限公司