TCP中,握手为什么是3次?

所谓三次握手(Three-way Handshake),是指建立一个 TCP 连接时,需要客户端和服务器总共发送3个包。

三次握手的目的是连接服务器指定端口,建立 TCP 连接,并同步连接双方的***和确认号,交换 TCP 窗口大小信息。

这里,我之前面试的时候,被问到一个引申的问题:为什么要3次?为什么一定是3次?2次行不行?4次呢?

我这里,只说为什么一定要3次,至于每次传什么样的包,里面的数据格式,我不关心。

一个连接的正常建立和数据的正常传输,核心是2点:对数据的接收和发送。只有确认了这2点,后续才能正常进行,如果接收和发送都不通,后面也就没有意义了

详细点说:客户要确认4件事:客户端自己是否具备数据的接收和发送功能;服务器端是否具备数据的接收和发送功能

同理,服务器端,也要确认4件事:服务器端自己是否具备数据的接收和发送功能;客户端是否具备数据的接收和发送功能
TCP中,握手为什么是3次?
图中的说明已经很清楚了,但是,为了严谨,我还是再说明一下。以第二次握手成功为例(前提是,第一次已经成功了)
说明:
1、客户端正确、正常收到了服务器传过来的消息,说明了,客户端自己的接收功能(C_C收)是正常的
2、C_C发 (客户端发送消息功能)正常,试想,如果客户端发送消息不正常,第一次握手,可能成功吗?既然成功进行了第二次握手,说明第一次成功,而第一次的成功,说明,客户端发送消息功能正常
3、客户端收到服务器发来的消息,说明,客户端,可以确认 服务器 具备发送数据功能,即:C_S发 正常
4、服务器能发送回来第二次握手的数据包,证明,第一次握手的数据包,服务器是正常接收到的,因为,客户端 可以的确认,服务器 具备接收数据功能,即:C_S收 正常

经过3次握手,最基本的功能,就确认了。在握手过程中,加上标识符什么的,确认是本次连接,不要和之前的、已过时的握手造成混乱就好了。

如果是2次握手,有不能确认的情况。如果是4次握手,造成的浪费。3次,是最简,最合理的!