TCP协议中的三次握手和四次挥手

本文详细解释了TCP连接建立时的三次握手和断开连接时的四次挥手机制,包括各阶段的具体操作和目的。
建立TCP连接需要三次握手而断开连接则需要四次挥手。
三次握手:
(1)第一次握手:建立连接时,客户端A发送SYN包(SYN=j)到服务器B,并进入SYN_SEND状态,等待服务器B确认。
(2)第二次握手:服务器B收到SYN包,必须确认客户A的SYN(ACK=j+1),同时自己也发送一个SYN包(SYN=k),即SYN+ACK包,此时服务器B进入SYN_RECV状态。
(3)第三次握手:客户端A收到服务器B的SYN+ACK包,向服务器B发送确认包ACK(ACK=k+1),此包发送完毕,客户端A和服务器B进入ESTABLISHED状态,完成三次握手。


完成三次握手,客户端与服务器开始传送数据。


四次挥手
(1)客户端A发送一个FIN,用来关闭客户A到服务器B的数据传送。 


(2)服务器B收到这个FIN,它发回一个ACK,确认序号为收到的序号加1。和SYN一样,一个FIN将占用一个序号。 (因为服务器端可能还有数据没有发送完成,所以不会立即断开连接,而是先发送一个ACK告知客户端已收到它发的FIN)


(3)等服务器端没有数据要发送了,服务器B准备关闭与客户端A的连接,发送一个FIN给客户端A。 


(4)客户端A发送ACK报文确认,并进入TIME_WAITE状态,如果服务器端B没有收到ACK则可以重传。服务器端B收到ACK后,就知道可以断开连接了。客户端A等待了2MSL后依然没有收到回复,则证明服务器端B已正常关闭,那好,客户端A也可以关闭连接了。


为什么连接的时候是三次握手,关闭的时候却是四次握手?
答:因为当Server端收到Client端的SYN连接请求报文后,可以直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。但是关闭连接时,当Server端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到我Server端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送。故需要四步握手。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值