面試突擊:為什么 TCP 需要三次握手?
TCP 三次握手是一道經(jīng)典的面試題,它是指 TCP 在傳遞數(shù)據(jù)之前,需要進(jìn)行 3 次交互才能正式建立起連接,并進(jìn)行數(shù)據(jù)傳遞。TCP 之所以需要 3 次握手是因?yàn)?TCP 雙方都是全雙工的。所謂全雙工指的是,TCP 任何一端既是發(fā)送數(shù)據(jù)方,又是接收數(shù)據(jù)方,因此這就要求 TCP 通訊雙方既要保證自己的發(fā)送能力,又要保證自己的接收能力才行。這就好像打電話時(shí),通訊雙方都要保證自己能話筒(傳遞聲音)和耳機(jī)(接收聲音)都是正常的才行,這樣才能進(jìn)行有效的交流,通常打電話時(shí),都是這樣開頭的:
- 我:喂,能聽到我說話嗎?
- 對(duì)方:能聽到你說話,你能聽到我說話嗎?
- 我:能聽到你說話,那我們就來聊正事吧。
TCP 三次握手也是相同的道理,3 次握手證明的能力詳情如下:
TCP 三次握手流程
TCP 三次握手流程如下:
- 客戶端發(fā)送 SYN 給服務(wù)器端,表示希望建立連接;
- 服務(wù)器端接收到消息之后,回應(yīng)一個(gè) SYN 和 ACK(確認(rèn)應(yīng)答)給客戶端;
- 客戶端收到服務(wù)器端的 SYN 報(bào)文之后,回應(yīng)一個(gè) ACK 報(bào)文。
具體執(zhí)行流程如下圖所示:
總結(jié)
TCP 之所以需要 3 次握手,是因?yàn)?TCP 通訊雙方都是全雙工的,所以要經(jīng)過 3 次交互才能確認(rèn)雙方的發(fā)送能力和接收能力,并且 TCP 握手必須是 3 次,如果是 2 次握手,不能證明服務(wù)器端的發(fā)送能力和客戶端的接收能力;也不能是 4 次握手,因?yàn)?3 次已經(jīng)能證明的事情,再交互握手 1 次完全沒有必要。
參考 & 鳴謝
《碼出高效:Java開發(fā)手冊(cè)》
《Offer 來了》