大家好,今天聊聊传输层通信协议 TCP 的经典问题:建连接与断连接。
网络上的传输是没有连接的,包括 TCP 也是一样的。
而 TCP 所谓的“连接”,其实只不过是在通讯的双方维护一个“连接状态”,让它看上去好像有连接一样。所以,TCP 状态变换是非常重要的。
很多人会问,为什么建链接要 3 次握手,断链接需要 4 次挥手?
-
对于建链接的 3 握手,主要是要初始化 Sequence Number 的初始值。通信的双方要互相通知对方自己的初始化的 Sequence Number(缩写为 ISN:Inital Sequence Number)——所以叫 SYN,全称 Synchronize Sequence Numbers。也就上图中的 x 和 y。这个号要作为以后的数据通信的序号,以保证应用层接收到的数据不会因为网络上的传输的问题而乱序(TCP 会用这个序号来拼接数据)。
-
对于 4 次挥手,其实你仔细看就是 2 次,因为 TCP 是全双工的,所以,发送方和接收方都需要 Fin 和 Ack。只不过,有一方是被动的,所以看上去就成了所谓的 4 次挥手。如果两边同时断连接,那就会进入到 CLOSING 状态,然后到达 TIME_WAIT 状态。下图是双方同时断连接的示意图