面试突击:为什么 TCP 需要三次握手?

发表于 讨论求助 2023-09-04 20:29:45

tcp 之所以需要 3 次握手,是因为 tcp 通讯双方都是全双工的,所以要经过 3 次交互才能确认双方的发送能力和接收能力,并且 tcp 握手必须是 3 次,如果是 2 次握手,不能证明服务器端的发送能力和客户端的接收能力;也不能是 4 次握手,因为 3 次已经能证明的事情,再交互握手 1 次完全没有必要。

tcp 三次握手是一道经典的面试题,它是指 tcp 在传递数据之前,需要进行 3 次交互才能正式建立起连接,并进行数据传递。tcp 之所以需要 3 次握手是因为 tcp 双方都是全双工的。所谓全双工指的是,tcp 任何一端既是发送数据方,又是接收数据方,因此这就要求 tcp 通讯双方既要保证自己的发送能力,又要保证自己的接收能力才行。这就好像打电话时,通讯双方都要保证自己能话筒(传递声音)和耳机(接收声音)都是正常的才行,这样才能进行有效的交流,通常打电话时,都是这样开头的:

  • 我:喂,能听到我说话吗?
  • 对方:能听到你说话,你能听到我说话吗?
  • 我:能听到你说话,那我们就来聊正事吧。

tcp 三次握手也是相同的道理,3 次握手证明的能力详情如下:

tcp 三次握手流程

tcp 三次握手流程如下:

  • 客户端发送 syn 给服务器端,表示希望建立连接;
  • 服务器端接收到消息之后,回应一个 syn 和 ack(确认应答)给客户端;
  • 客户端收到服务器端的 syn 报文之后,回应一个 ack 报文。

具体执行流程如下图所示:

总结

tcp 之所以需要 3 次握手,是因为 tcp 通讯双方都是全双工的,所以要经过 3 次交互才能确认双方的发送能力和接收能力,并且 tcp 握手必须是 3 次,如果是 2 次握手,不能证明服务器端的发送能力和客户端的接收能力;也不能是 4 次握手,因为 3 次已经能证明的事情,再交互握手 1 次完全没有必要。

参考 & 鸣谢

《码出高效:java开发手册》

《offer 来了》

发表
26906人 签到看排名