TCP三次握手与四次挥手

转载自:blog.csdn.net/whuslei(部分改动加上自己理解)


最近在做导师布置的socket中转服务器,想把TCP捋一捋,发现此文十分易懂,感谢作者。

TCP三次握手与四次挥手
总流程

三次握手

第一次握手:首先Client端发送连接请求报文SYN(SYN:同步序列编号(Synchronize Sequence Numbers)。),然后进入SYN_SEND状态。
第二次握手:Server段接受连接请求后回复ACK报文(确认),同时自己已发出SYN报文,进入SYN-RECV状态,并为这次连接分配资源。
第三次握手:Client端接收到ACK+SYN报文后也向Server段发生ACK报文(确认),并分配资源,这样TCP连接就建立了,双端都进入ESTABLISH状态。
四次挥手

[ 注意]中断连接端可以是Client端,也可以是Server端。
假设Client端发起中断连接请求,也就是发送FIN报文。Server端接到FIN报文后,意思是说" 我Client端没有数据要发给你了 ",但是如果你还有数据没有发送完成,则不必急着关闭Socket,可以继续发送数据。所以你先发送ACK," 告诉Client端,你的请求我收到了,但是我还没准备好,请继续你等我的消息 "。这个时候Client端就进入FIN_WAIT状态,继续等待Server端的FIN报文。当Server端确定数据已发送完成,则向Client端发送FIN报文," 告诉Client端,好了,我这边数据发完了,准备好关闭连接了 "。Client端收到FIN报文后," 就知道可以关闭连接了,但是他还是不相信网络,怕Server端不知道要关闭,所以发送ACK后进入TIME_WAIT状态,如果Server端没有收到ACK则可以重传 。“,Server端收到ACK后," 就知道可以断开连接了 "。Client端 等待了2MSL(计时等待) 后依然没有收到回复,则证明 Server端已正常关闭,那好,我Client端也可以关闭连接了 。Ok,TCP连接就这样关闭了!
【注意】  在TIME_WAIT状态中,如果TCP client端最后一次发送的ACK丢失了,它将重新发送。最后一次ACK应答包发出去之后,若Server未收到;Server端会定时重发FIN报文,这时Client就会知道自己的ACK报文没有发送成功。TIME_WAIT状态中所需要的时间是依赖于实现方法的。典型的值为30秒、1分钟和2分钟。等待之后连接正式关闭,并且所有的资源(包括端口号)都被释放。
【问题1】为什么连接的时候是三次握手,关闭的时候却是四次握手?
答:因为当Server端收到Client端的SYN连接请求报文后,可以直接发送SYN+ACK报文。 其中ACK报文是用来应答的,SYN报文是用来同步的 。但是关闭连接时,当Server端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到我Server端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送。故需要四步握手。
【问题2】为什么TIME_WAIT状态需要经过2MSL(最大报文段生存时间)才能返回到CLOSE状态?
答:虽然按道理,四个报文都发送完毕,我们可以直接进入CLOSE状态了,但是我们 必须想象网络是不可靠的,有可能最后一个ACK丢失 。所以TIME_WAIT状态就是 用来重发可能丢失的ACK报文

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值