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

语言: CN / TW / HK

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第1天,点击查看活动详情

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

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

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

TCP 三次握手流程

TCP 三次握手流程如下:

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

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

总结

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

参考 & 鸣谢

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

《Offer 来了》

是非审之于己,毁誉听之于人,得失安之于数。

公众号:Java面试真题解析

面试合集:http://gitee.com/mydb/interview