TCP状态变迁

连接建立:连接建立分要经过三次握手过程:
[quote]
1)客户端发送一个SYN段到指明客户打算连接的服务器的端口,报文段中要设置客户端初始序号。
2)服务器发回包含服务器的初始序号的SYN报文段作为应答。同时,将确认序号设置为客户的初始序号加1,并设置ACK位标志报文段为确认报文段。
3)客户端必须将确认序号设置为服务器初始序号加1,对服务器的SYN报文段进行确认。[/quote]

关闭连接:
[quote]
当客户端请求关闭连接时,客户端发送一个FIN包后,客户端就进入FIN_WAIT_1状态,等待对方的确认包,
服务器发送一个ACK包给客户,客户端收到ACK包后结束FIN_WAIT_1状态,进入FIN_WAIT_2状态,等待服务器发过来的关闭请求,
服务器发一个FIN包后,进入CLOSE_WAIT状态,
当客户端收到服务器的FIN包,FIN_WAIT_2状态就结束,然后给服务器端的FIN包给以一个确认包,客户端这时进入TIME_WAIT,
当服务器收到确认包后,CLOSE_WAIT状态结束了,
这时候服务器端真正的关闭了连接.但是客户端还在TIME_WAIT状态下,
[/quote]

[quote]
什么时候结束呢.我在这里再讲到一个新名词:2MSL等待状态,其实TIME_WAIT就是2MSL等待状态,
为什么要设置这个状态,原因是有足够的时间让ACK包到达服务器端,如果服务器端没收到ACK包,超时了,然后重新发一个FIN包,直到服务器收到ACK 包.

TIME_WAIT状态等待时间是在TCP重新启动后不连接任何请求的两倍.
大家有没有发现一个问题:如果对方在第三次握手的时候出问题,如发FIN包的时候,不知道什么原因丢了这个包,然而这边一直处在FIN_WAIT_2状 态,而且TCP/IP并没有设置这个状态的过期时间,那他一直会保留这个状态下去,越来越多的FIN_WAIT_2状态会导致系统崩溃.
[/quote]


[img]http://dl.iteye.com/upload/attachment/543897/ace67b04-ac80-3459-b71b-d44c6c83426f.gif[/img]


状态:描述
[list]
[*]CLOSED:无连接是活动的或正在进行
[*]LISTEN:服务器在等待进入呼叫
[*]SYN_RECV:一个连接请求已经到达,等待确认
[*]SYN_SENT:应用已经开始,打开一个连接
[*]ESTABLISHED:正常数据传输状态
[*]FIN_WAIT1:应用说它已经完成
[*]FIN_WAIT2:另一边已同意释放
[*]ITMED_WAIT:等待所有分组死掉
[*]CLOSING:两边同时尝试关闭
[*]TIME_WAIT:另一边已初始化一个释放
[*]LAST_ACK:等待所有分组死掉
[/list]

你可能感兴趣的:(Linux)