CCIE思科教育培训 CCIE培训

TCP建立连接和断开连接

 建立TCP连接需要三次握手才可以建立,断开连接则需要四次握手。
 图1:

第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,进入SYN_SENT状态,等待服务器确认,
第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态,
第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。
注:

SYN_RECV:一个连接请求已经到达,等待确认
 

SYN_SENT:应用已经开始,打开一个连接

ESTABLISHED:正常数据传输状态    

首先Client端发送连接请求报文,Server段接收连接后回复ACK报文(Acknowledgement,确认发来的数据已经接收完毕),为此次连接分配资源。Client端在收到ACK报文后也向Server端发送ACK报文,并分配资源,如此TCP连接就建立了。

补充知识

在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG.其中,对于我们日常的分析有用的就是前面的五个字段。它们的含义是:SYN表示建立连接,FIN表示关闭连接,ACK表示响应,PSH表示有 DATA数据传输,RST表示连接重置。其中,ACK是可能与SYN,FIN等同时使用的,比如SYN和ACK可能同时为1,它表示的就是建立连接之后的响应,如果只是单个的一个SYN,它表示的只是建立连接。 

断开连接详解图如下(关闭连接可以是Client也可以是Server) 图2:   我们假设Client发送中断请求(Fin),Server接到请求后表示关闭连接,但可以不必着急关闭通信(Socket),可以继续发送数据,所以Server先发送ACK,表明关闭请求已收到,但为了保证数据接收完成,请等待,稍后会给client消息,此时Client进入FIN_WAIT1状态,等待server的FIN

 (这里讲一下FIN_WAIT状态,Client发出FIN,同时进入FIN_WAIT1状态,Server响应ACK,从而使Client变成FIN_WAIT2状态,接着Server会发出FIN,Client响应ACK,同时变成TIME_WAIT状态,这就是关闭连接时FIN_WAIT状态的变化)

当Server端确定数据已经发送完成,则会向Clinet发送FIN报文,意思是告诉Client,我这边已经准备完毕,可以关闭连接,Client接收到FIN报文以后就明白可以关闭连接了,但为了防止网络问题,所以发送ACK后进入FIN_WAIT状态,Server如果没有收到ACK也可以重传,当Server收到ACK后就可以断开连接了,Client等待2MSL后没有收到重传则证明Server已经正常关闭

(再讲一下2MSL,Maximum Segment Lifetime,译为报文最大生存时间,是用来补救的,确认无误ACK没有丢失,如果TCP client端最后一次发送的ACK丢失了,它将在等待时间内重新发送。)

这样Client端也会关闭,OK, TCP连接经过四次握手后也正常关闭。

Tags:

发布: admin 分类: CCIE思科 评论: 0 浏览: 90
留言列表
发表留言
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。