TCP 三次握手和四次挥手的最后一步的意义
为什么TCP的握手需要最后一步/两次握手不行吗
因为可能存在这样的一个状态:客户端发送一个连接请求给服务端,但是这个请求在网络中阻塞了,没有到达服务端,客户端超时重传请求连接这个时候发送成功了,建立连接,。。。。。。,通信结束,断开连接。 后来请求连接到达了服务端,服务端认为客户端要和我连接,返回SYN=1的确认报文给客户端,如果只有两次握手,此时连接就建立了,但是客户端并没有这个需求,就会忽略这个确认报文。此时服务端的资源就造成了浪费,因此需要第三次握手确认客户端也有要连接的需求。
为什么TCP释放连接客户端要等待2MSL
首先我们来说一下2MSL是什么。
2MSL是最大报文生存时间,也就是如果系统认为如果你发送一个报文最长的时间需要1MSL。因此在我发送了一个报文后,2MSL的时间我没有收到你的回复,我就认为这个报文丢失了,那么需要重传。
在客户端向服务端发送了最后一次的挥手后,客户端仍然需要等待2MSL的时间,才可以断开连接,这是为了确保客户端最后发送的ACK被服务端收到了。
首先服务端发送第三次挥手FIN报文,客户端收到后,会发送第四次挥手 ACK报文,如果服务端在2MSL的时间内没有收到客户端的ACK报文,那么服务端会超时重传一个FIN的报文这个报文最晚到达客户端的时间就是2MSL因为服务端的第三个报文需要1MSL的时间到达客户端,这里距离服务端超时重传还需要1MSL,然后服务端发送报文到客户端的时间为1MSL因此在客户端发送最后一个确认报文后,还需要等到2MSL,查看服务端是不是没收到我的最后一个报文导致超时重传了。
如果没等待就断开了,服务器有可能一直发送超时重传的ACK,这个端口复用之后有可能会收到之前服务端发来的ack请求(过期的)造成数据混乱
因此2MSL可以保证服务器的连接正常断开且数据网络中没有残留的tcp报文
|