原文:什么是2MSL以及TIME_WAIT的作用

TIME WAIT主要是用来解决以下几个问题: 上面解释为什么主动关闭方需要进入TIME WAIT状态中提到的: 主动关闭方需要进入TIME WAIT以便能够重发丢掉的被动关闭方FIN包的ACK。如果主动关闭方不进入TIME WAIT,那么在主动关闭方对被动关闭方FIN包的ACK丢失了的时候,被动关闭方由于没收到自己FIN的ACK,会进行重传FIN包,这个FIN包到主动关闭方后,由于这个连接已经不 ...

2018-11-21 10:34 0 3477 推荐指数:

查看详情

TCP time_wait为什么持续2MSL

time_wait timewait先发起close的一端的第二阶段: a fin b,b ack a,b fin a 此时a收到b的fin之后,a处于time_wait,a无法确定自己接下来的ack of fin是否被b收到,所以time_wait还是会持续一段时间。接着可能发生两件事 ...

Thu Apr 11 23:05:00 CST 2019 0 806
为什么TCP的TIME_WAIT状态要维持2MSL

本文主要分析为什么TIME_WAIT状态的持续时间是2MSL而不是1MSL,3MSL或其它的时长,而不会详细描述为什么需要TIME_WAIT状态。 阅读本文需要的预备知识: 了解TCP协议的状态变迁; 了解TCP拆链的四次挥手过程; 了解为什么需要TIME_WAIT状态 ...

Tue Jul 14 18:11:00 CST 2020 0 756
为什么tcp的TIME_WAIT状态要维持2MSL

本文主要分析为什么TIME_WAIT状态的持续时间是2MSL而不是1MSL,3MSL或其它的时长,而不会详细描述为什么需要TIME_WAIT状态。 阅读本文需要的预备知识: 了解TCP协议的状态变迁; 了解TCP拆链的四次挥手过程; 了解为什么需要TIME_WAIT状态 ...

Wed Jun 05 01:02:00 CST 2019 2 1798
TCP四次挥手为何需要TIME_WAIT以及为何是2MSL

根据第三版《UNIX网络编程 卷1》2.7节,TIME_WAIT状态的主要目的有两个: 优雅的关闭TCP连接,也就是尽量保证被动关闭的一端收到它自己发出去的FIN报文的ACK确认报文; 处理延迟的重复报文,这主要是为了避免前后两个使用相同四元组的连接中的前一个连接的报文干扰后一个 ...

Sat Mar 14 01:31:00 CST 2020 0 1004
TCP释放连接时为什么time_wait状态必须等待2MSL时间

为什么上图中的A在TIME-WAIT状态必须等待2MSL时间呢? 第一,为了保证A发送的最后一个ACK报文能够到达B。这个ACK报文段有可能丢失,因而使处在LAST-ACK状态的B收不到对已发送的FIN+ACK报文段的确认。B会超时重传这个FIN+ACK报文段,而A就能在2MSL时间内收到这个重传 ...

Tue Jan 10 03:37:00 CST 2017 1 13360
Time-wait状态(2MSL)一些理解

1. 编写TCP/SOCK 服务时,SO_REUSEADDR到底是什么意思? 这个套接字选项通知内核,如果端口忙,但TCP状态处于TIME_WAIT,可以重用端口。如果端口忙,TCP状态处于其他状态,重用端口时依旧指明“地址已经在使用中”。如果你的服务程序停止后向立刻重启,而新套接字依旧使用 ...

Sat Oct 10 02:54:00 CST 2020 0 876
为什么是2MSL而不是MSL

为什么等待2MSL,从TIME_WAIT到CLOSE? 在Client发送出最后的ACK回复,但该ACK可能丢失。Server如果没有收到ACK,将不断重复发送FIN片段。所以Client不能立即关闭,它必须确认Server接收到了该ACK。Client会在发送出ACK之后 ...

Wed Mar 02 19:22:00 CST 2016 0 3288
TIME_WAIT详解

客户端与服务器端建立TCP/IP连接后关闭SOCKET后,服务器端连接的端口状态为TIME_WAIT.主动关闭的一方在发送最后一个 ack 后,就会进入 TIME_WAIT 状态 停留2MSL(max segment lifetime)时间,这个是TCP/IP必不可少的,也就是“解决”不了的,也就 ...

Thu Aug 05 00:51:00 CST 2021 0 205
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM