庄周梦蝶

生活、程序、未来
   :: 首页 ::  ::  :: 聚合  :: 管理

TCP的TIME_WAIT状态

Posted on 2008-06-23 01:25 dennis 阅读(17831) 评论(3)  编辑  收藏 所属分类: 计算机科学与基础
    主动关闭的Socket端会进入TIME_WAIT状态,并且持续2MSL时间长度,MSL就是maximum segment lifetime(最大分节生命期),这是一个IP数据包能在互联网上生存的最长时间,超过这个时间将在网络中消失。MSL在RFC 1122上建议是2分钟,而源自berkeley的TCP实现传统上使用30秒,因而,TIME_WAIT状态一般维持在1-4分钟。
    TIME_WAIT状态存在的理由:
1)可靠地实现TCP全双工连接的终止
    在进行关闭连接四路握手协议时,最后的ACK是由主动关闭端发出的,如果这个最终的ACK丢失,服务器将重发最终的FIN,因此客户端必须维护状态信息允许它重发最终的ACK。如果不维持这个状态信息,那么客户端将响应RST分节,服务器将此分节解释成一个错误(在java中会抛出connection reset的SocketException)。因而,要实现TCP全双工连接的正常终止,必须处理终止序列四个分节中任何一个分节的丢失情况,主动关闭的客户端必须维持状态信息进入TIME_WAIT状态。

2)允许老的重复分节在网络中消逝 
    TCP分节可能由于路由器异常而“迷途”,在迷途期间,TCP发送端可能因确认超时而重发这个分节,迷途的分节在路由器修复后也会被送到最终目的地,这个原来的迷途分节就称为lost duplicate。在关闭一个TCP连接后,马上又重新建立起一个相同的IP地址和端口之间的TCP连接,后一个连接被称为前一个连接的化身(incarnation),那么有可能出现这种情况,前一个连接的迷途重复分组在前一个连接终止后出现,从而被误解成从属于新的化身。为了避免这个情况,TCP不允许处于TIME_WAIT状态的连接启动一个新的化身,因为TIME_WAIT状态持续2MSL,就可以保证当成功建立一个TCP连接的时候,来自连接先前化身的重复分组已经在网络中消逝。

新的SCTP协议通过在消息头部添加验证标志避免了TIME_WAIT状态。

评论

# re: TCP的TIME_WAIT状态  回复  更多评论   

2009-03-09 17:07 by Joshua Zhu
庄老大,我也写了一篇关于TIME_WAIT和CLOSE_WAIT的,还有我的山寨版TCP状态转换图:
http://blog.zhuzhaoyuan.com/2009/03/a-word-on-time_wait-and-close_wait/
哈哈哈。

# re: TCP的TIME_WAIT状态  回复  更多评论   

2009-03-10 10:04 by dennis
@Joshua Zhu
老猪,做个友情链接 :D

# re: TCP的TIME_WAIT状态  回复  更多评论   

2009-03-10 18:35 by Joshua Zhu
庄老大,加了 :)

只有注册用户登录后才能发表评论。


网站导航: