先上转换图:

  重点研究TIME_WAIT状态,根据UNIX网络编程中的思路,TIME_WAIT状态有两个存在的理由:

理由1、

  客户端执行主动关闭,假设最终的ACK丢失,服务器将重新发送它的最后那个FIN,因此客户端必须维护状态信息,以允许它重新发送最终那个ACK,要是客户端 不维护状态信息,它将响应一个RST分节,该分节将被服务器解释成一个错误,如果TCP打算执行所有必要的工作以彻底终止连接上两个方向的数据流,那么它必须正确处理连接终止序列4个分节中任何一个分节丢失的情况。为什么执行主动关闭的那一端是处于TIME_WAIT状态的那一端:因为可能不得不重传最终那个ACK的就是那一端。

  看了理由1的解释,想必还是有点蒙,根据个人的理解,给出一个通俗的解释:

  MSL是最长分节生命期,也即一个分节在网络中传输,如果经过MSL时间还没有到达目的地,则这个分节自动失效。TIME_WAIT状态的超时时间是2MSL,就是如果TCP处于TIME_WAIT状态时,经过2MSL的时间后悔自动转到CLOSED状态。如果在TIME_WAIT状态时收到服务器发来的FIN,则会回复一个ACK。从图中可以看到,正常情况下,是从FIN_WAIT_2状态回复ACK然后转到TIME_WAIT状态的。而在TIME_WAIT状态恢复ACK则会转到CLOSED状态,不用等到超时时间到。

  要是客户端不维护状态信息,也即没有TIME_WAIT状态,则客户端在FIN_WAIT_2状态回复ACK后直接回到CLOSED状态,来看看这样会存在什么问题,如果客户端在FIN_WAIT_2状态回复的这个ACK丢失了,而服务器由于超时没有接到ACK则会再一次发送FIN给客户端,这时的客户端是处于CLOSED状态的,当它接到FIN后会回复一个RST,服务器如果接到了这个RST则会解释成一个错误,这明显不是我们期望的。因此,客户端维护一个TIME_WAIT状态也就是有必要的了,在TIME_WAIT状态时收到FIN并回复ACK,然后回到CLOSED状态,这样客户端就功成身退了。读到这里,可能有读者会迷惑,如果在TIME_WAIT状态回复的这个ACK再次丢失呢,那处于CLOSED状态的客户端不还是会再次接收到服务端发来的FIN,然后回复RST吗?我想说不会的,这个ACK即使再丢失,服务端也不会回复FIN的,处于CLOSED状态的客户端也就不会再接收到FIN。要不然,在网络不稳定的情况下,客户端和服务器会陷入死循环,永远无法走出困境。看下面的分析。

  解释一下为什么客户端的TIME_WAIT状态的超时时间是2MSL? 假设0时刻,客户端接收到服务端的第一次FIN,并回复ACK,进入TIME_WAIT状态。经过MSL时间,服务端没有收到这个ACK,判定超时,因此,再次发送FIN给客户端(正常情况下,服务器在CLOSE_WAIT状态第一次发送FIN,然后进入LAST_ACK状态,如果没有成功接收到客户端的ACK,则第一次超时后再次发送FIN,这次是从LAST_ACK开始的,发送完FIN后继续留在LAST_ACK状态,如果这次再超时便转入CLOSED状态,因此,以后就不会再发送FIN了,这正好解释了上面的红色部分),这个FIN的存活期最多也为MSL,如果在MSL时间内成功到达客户端,则客户端这时还处于TIME_WAIT状态,可以正确处理这个FIN,如果这个FIN在MSL时间内没有到达客户端,则自动失效,客户端也进入CLOSED状态,功成身退。

  假如设计者让客户端处于TIME_WAIT状态的超时时间小于2MSL的话,我们再从头分析一次,0时刻,客户端接收到服务端的第一次FIN,并回复ACK,进入TIME_WAIT状态。经过MSL时间,服务端没有收到这个ACK,判定超时,因此,再次发送FIN给客户端,这个FIN存活期最多为MSL,如果FIN在MSL时间的最后一刻到达客户端,由于TIME_WAIT状态的超时时间小于2MSL,客户端已经回到了CLOSED状态,在CLOSED状态接收到FIN必然会回复RST,这是我们不希望的。因此,TIME_WAIT状态的超时时间要大于等于2MSL。

理由2:

  我们假设在12.106.32.254的1500端口和206.168.112.219的21端口之间有一个TCP连接,我们关闭这个连接,过一段时间后,我们在相同的IP地址和端口之间建立另一个连接,后一个连接称为前一个连接的化身,因为他们的IP地址和端口号都相同,如果不存在TIME_WAIT状态的话,这个连接可以成功建立,而此时可能还有上一个连接的分节在网络中传输,还没有超过MSL时间而死掉。在相同的IP地址和端口上的新连接建立好之后,可能有一端会收到这个分节,这时我们不期望的。因此,设置了TIME_WAIT状态,TCP协议栈不会给处于TIME_WAIT状态的IP和端口建立连接,而直到超时2MSL时间退出TIME_WAIT状态后才可以建立新连接,这时网络中的相同IP和端口上的旧连接中的分节也早就死了。

TCP状态转化图 TIME_WAIT解析的更多相关文章

  1. TCP建立连接和释放的过程,及TCP状态变迁图

    一.TCP报文格式 下面是TCP报文格式图: 重要字段介绍: (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记. (2)确认序号:Ack序号,占 ...

  2. Linux记录-TCP状态以及(TIME_WAIT/CLOSE_WAIT)分析(转载)

    1.TCP握手定理 2.TCP状态 l  CLOSED:初始状态,表示TCP连接是“关闭着的”或“未打开的”. l  LISTEN :表示服务器端的某个SOCKET处于监听状态,可以接受客户端的连接. ...

  3. TCP状态变迁图

    服务端,端口的状态变化 先在本机(IP地址为:192.168.1.10)配置FTP服务,然后在其它计算机(IP地址为:192.168.1.1)访问FTP服务,从TCPView看看端口的状态变化. 下面 ...

  4. TCP/IP详解--连接状态变迁图CLOSE_WAIT

    终止一个连接要经过4次握手.这由TCP的半关闭(half-close)造成的.既然一个TCP连接是全双工(即数据在两个方向上能同时传递,可理解为两个方向相反的独立通道),因此每个方向必须单独地进行关闭 ...

  5. TCP状态转换图解析

    本文参考Unix网络编程卷1,对TCP状态转换进行总结,方便掌握TCP链接中各个状态及故障分析. 1.Linux下TCP相关工具 基于Linux系统查看网络状态,首先了解几个基本查看指令. Linux ...

  6. tcp连接的状态变迁以及如何调整tcp连接中处于time_wait的时间

    一.状态变迁图 二.time_wait状态 针对time_wait和close_wait有个简单的描述帮助理解: Due to the way TCP/IP works, connections ca ...

  7. TCP三次握手,四次挥手,状态变迁图

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  8. tcp状态-TIME_WAIT与CLOSE_WAIT带来的坑

    tcp状态: http://www.cnblogs.com/DengGao/p/tcp_state.html 1. tcp连接会占用系统资源(文件描述符), 有时候甚至会导致系统假死(不能发起或者处理 ...

  9. 关于TCP状态TIME_WAIT的理解

    1.TIME_WAIT的作用: TIME_WAIT状态存在的理由:1)可靠地实现TCP全双工连接的终止 在进行关闭连接四次挥手协议时,最后的ACK是由主动关闭端发出的,如果这个最终的ACK丢失,服务器 ...

随机推荐

  1. java ShutdownHook介绍与使用

    Java程序经常也会遇到进程挂掉的情况,一些状态没有正确的保存下来,这时候就需要在JVM关掉的时候执行一些清理现场的代码.JAVA中的ShutdownHook提供了比较好的方案. JDK提供了Java ...

  2. python 获取IP

    第一种 import commandscmd = "ifconfig br0 | grep 'inet addr' | sed 's/^.*addr://g' |sed 's/ Bcast: ...

  3. C++ 在容器A中查找最后出现的容器B中的元素,并返回iterator(find_end)

    #include <iostream> // cout #include <algorithm> // find_end #include <vector> // ...

  4. Javascript 面向对象-继承

    JavaScript虽然不是面向对象的语言,但是我们通过构造可以让其支持面向对象,从而实现继承.重写等面向对象的特性.具体代码如下: //创建类Person function Person(age,n ...

  5. 雷林鹏分享:C# 索引器(Indexer)

    C# 索引器(Indexer) 索引器(Indexer) 允许一个对象可以像数组一样被索引.当您为类定义一个索引器时,该类的行为就会像一个 虚拟数组(virtual array) 一样.您可以使用数组 ...

  6. arcgis for silverlight 地图放大到某个点或者几何对象

    http://blog.csdn.net/xuan444150/article/details/7727866   分类: silverlight王国 GIS王国 2012-07-09 08:50 1 ...

  7. 20161226xlVBA演示文稿替换文字另存pdf

    Const ModelText As String = "机构名称" Const ModelName As String = "测试文件.pptx" Sub N ...

  8. codeforces 497c//Distributing Parts// Codeforces Round #283(Div. 1)

    题意:有n个区间[ai,bi],然后有n个人落在[ci,di],每个人能用ki次.问一种方式站满n个区间. 两种区间都用先x后y的升序排序.对于当前的区间[ai,bi],将ci值小于当前ai的全部放入 ...

  9. [INS-20802] Oracle Net Configuration Assistant failed,Caught UnknownHostException

    在64位Centos上安装64的oracle 11g R2,出现错误: [INS-20802] Oracle Net Configuration Assistant failed 根据提示查看日志文件 ...

  10. Confluence 6 管理多目录概述

    这里是有关目录顺序如何影响处理流程: 目录中的顺序是被用来如何查找用户和组的顺序. 修改用户和用户组将会仅仅应用到应用程序具有修改权限的第一个目录中. 配置目录载入顺序 你可以修改在 Confluen ...