TIME_WAIT 为主动关闭的那端最后经历的状态,持续时间为2MSL。
MSL 是 Maxmum Segment Lifetime 报文最大生存时间。一般根据实际的网络情况进行确定。
为什么要持续这么长的时间?
原因一:可靠地实现 TCP 全双工连接的终止
主动关闭端(客户端)的最后一个 ACK 确认包可能会丢失,这时服务器就会超时重传第三次挥手的 FIN 信息报,然后客户端再重传第四次挥手的 ACK 报文。如果没有这 2MSL,客户端直接关闭连接,再次接收服务器超时重传的 FIN 信息报时,会响应 RST(Reset),用来异常的关闭连接,服务端接受 RST 包后执行异常处理(不必发送 ACK 包来确认)。
原因二:让本次连接产生的所有报文段都从网络中消失
TCP 分节可能由于路由器异常而“迷途”,发送端(客户端)确认超时而重发这个分节,“迷途”的分节最终还是会被送到接收端(客户端)。如果没有这 2MSL ,客户端直接关闭连接。此时如果重新建立一个相同的 IP 地址和端口之间的 TCP 连接后,这个“迷途”的分节会被新连接接受,这会破坏新的 TCP 连接的可靠性。
注意: TCP 连接处于 2MSL 连接等待期间,定义这个连接的四元组,即,客户端 IP 地址和端口,服务端 IP 地址和端口号,不能被使用。
高并发短连接会使服务器因端口资源不足而拒绝为一部分客户服务(存在大量 TIME_WAIT),服务器资源严重浪费。这种情况下可以通过 TIME_WAIT 的重用和快速回收进行处理。