tcp 协议TIME_WAIT状态详解


上一篇文章提到执行主动关闭的一端进入 tcp TIME_WAIT状态,关于原因,unix网络编程卷一中给出两点:


1. 实现终止TCP全双工链接的可靠性,即保证tcp连接可靠断开。

2. 让老的重复分节在网络中消失
第一个原因的解释,执行主动关闭的一端最终会发ACK给对端,如果这个ACK最终丢失,那么发FIN的对端将由于在等待ACK超时后重发FIN分节,而如果主动关闭的一端在发完最终的ACK后清除此连接上状态信息,当再次收到对端的FIN分节时由于找不到对应的连接而报错,所以,如果TCP想彻底终止某个连接上两个方向的数据流(即全双工关闭),那么它必须处理连接终止序列四个分节中任何一个分节丢失的情况,这就是为何执行主动关闭的一端进入TIME_WAIT状态的第一个原因,因为它可能不得不重发最终的ACK分节给对端。

第二个原因,假设在一对ip及port上有一个连接,关闭这个连接后立即又建立起新的连接(同ip port),后一个连接为前一个的化身,因为ip port相同,tcp 必须防止来自某个连接的老分组在连接终止后再现,从而影响新连接的数据交互,所以tcp不能给处于TIME_WAIT状态的连接启动新的化身,从而被误解成属于同一连接。
TIME_WAIT状态的持续时间是最长分节生命期MSL(max segment lifetime)的2倍,即2MSL,既然tcp规定一个分节在网络中最大生存时间是 MSL,这足够让某个方向上的分节最多存活MSL秒即被丢弃,另一个方向的应答最多存活MSL秒也被丢弃,通过这个规则,就能保证当成功建立一个tcp连接时,来自该链接的之前所有连接的老的重复分组在网络中已消失。


每个TCP/IP 协议栈必须选择一个 MSL值,rfc 1122建议值为2分钟,而源自berkely的实现是30秒,需要注意的是如果此值过大,则在高并发服务器中tcp/ip协议栈必然要维护大量的TIME_WAIT状态的连接而消耗资源,所以一般作网络服务器优化时通常经过改小此值来减少维护此状态的资源。

详细设置及解决如下:

timeout_timewait 参数
描述:确定 TCP/IP 在释放已关闭的连接并再次使用其资源前必须经过的时间。关闭与释放之间的这段时间称为 TIME_WAIT 状态或者两倍最大段生存期(2MSL)状态。此时间期间,重新打开到客户机和服务器的连接的成本少于建立新连接。通过减少此条目的值,TCP/IP 可以更快地释放关闭的连接,并为新连接提供更多资源。如果正在运行的应用程序需要快速释放连接、创建新的连接,并且因为许多连接处于 TIME_WAIT 状态而导致低吞吐量,那么调整此参数。
如何查看或设置:
在我的ubuntu系统上此值为:
#cat /proc/sys/net/ipv4/tcp_fin_timeout
60
发出以下命令,将 timeout_timewait 参数设置为 30 秒:

#echo 30 > /proc/sys/net/ipv4/tcp_fin_timeout
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TIME_WAITTCP协议中的一种状态,当一端关闭了连接后,它会进入TIME_WAIT状态,并在一段时间内保持这个状态。在这个状态下,该端口在连接释放之后仍然不能被其他新连接使用,因为它需要等待足够长的时间来确保之前的连接已经完全关闭。 引用提到了通过设置SO_LINGER标志来避免socket进入TIME_WAIT状态。这种方法可以通过发送RST包来代替正常的TCP四次握手来终止连接。然而,这并不是一个推荐的做法,因为TIME_WAIT状态对于我们来说通常是有利的。 引用指出,CLOSE_WAIT状态是由于某一方没有正确关闭连接导致的。这种状态发生在一方网络连接断开后,并未执行closesocket操作,导致连接状态停留在CLOSE_WAIT状态。与CLOSE_WAIT相对应的是TIME_WAIT状态。 引用提到了解决大量TIME_WAIT状态连接的方法之一是通过调整内核参数。在/etc/sysctl.***的快速回收。 综上所述,TIME_WAITTCP协议中用于确保连接完全关闭的一种状态。虽然有一些方法可以避免进入TIME_WAIT状态,但通常来说,TIME_WAIT对于连接的正常关闭是有利的。调整内核参数也可以解决大量TIME_WAIT状态连接的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [TCP/IP的time_wait状态详解](https://blog.csdn.net/tianmo2010/article/details/7436157)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [关于面试经常被问到的socket的TIME_WAIT状态的原因及解决办法和避免的办法](https://blog.csdn.net/wu936754331/article/details/49104497)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值