本文主要是想通过抓包工具分析一下TCP三次握手和断开过程:
1、TCP三次握手建立连接和断开连接解释,如下图:
![120b295618b2ff7ad5d7ffceffbd46b3.png](https://i-blog.csdnimg.cn/blog_migrate/7c24728e96b0413a164c3f1fb54812e8.jpeg)
TCP三次握手建立连接和断开连接
2、通过WireShark抓包查看这个TCP过程,数据如下图和可以结合上图一起看:
![b5f945415c694e8c954caf05eef07dc6.png](https://i-blog.csdnimg.cn/blog_migrate/a8d0975e39d78936b00c96449443c23d.jpeg)
Wireshark tcp抓包数据
3、为什么上图中的客户端在TIME-WAIT状态必须等待2MSL时间呢?
第一,为了保证客户端发送的最后一个ACK报文能够到达服务器。这个ACK报文段有可能丢失,因而使处在LAST-ACK状态的服务器收不到对已发送的FIN+ACK报文段的确认。服务器会超时重传这个FIN+ACK报文段,而客户端就能在2MSL时间内收到这个重传的FIN+ACK报文段。
如果客户端在TIME-WAIT状态不等待一段时间,而是在发送完ACK报文段后就立即释放连接,就无法收到服务器重传的FIN+ACK报文段,因而也不会再发送一次确认报文段。这样,服务器就无法按照正