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


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

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

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

原因 1

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

原因 2

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

注意

主动关闭连接的一方在收到重传的 FIN+ACK 报文后,会重置 TIME_WAIT 状态的等待时长

遗留问题

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_TIMEWAIT_LEN (60*HZ) /* how long to wait to destroy TIME-WAIT
				  * state, about 60 seconds	*/

假设一种情况,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 相违背

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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值