白話TCP為什麼需要進行三次握手

westwolf發表於2021-09-09

閱讀本文大概需要 2.3 分鐘。

作者:雨林

https://www.cnblogs.com/yuilin

首先簡單介紹一下TCP三次握手

在TCP/IP協議中,TCP協議提供可靠的連線服務,採用三次握手建立一個連線。

第一次握手:建立連線時,客戶端傳送syn包(syn=j)到伺服器,並進入SYN_SEND狀態,等待伺服器確認;

第二次握手:伺服器收到syn包,必須確認客戶的SYN(ack=j+1),同時自己也傳送一個SYN包(syn=k),即SYN+ACK包,此時伺服器 進入SYN_RECV狀態;

第三次握手:客戶端收到伺服器的SYN+ACK包,向伺服器傳送確認包ACK(ack=k+1),此包傳送完畢,客戶端和伺服器進入 ESTABLISHED狀態,完成三次握手。

透過這樣的三次握手,客戶端與服務端建立起可靠的雙工的連線,開始傳送資料。

三次握手的最主要目的是保證連線是雙工的,可靠更多的是透過重傳機制來保證的。

但是為什麼一定要進行三次握手來保證連線是雙工的呢,一次不行麼?兩次不行麼?我們舉一個現實生活中兩個人進行語言溝通的例子來模擬三次握手。

第一次對話:

老婆讓甲出去打醬油,半路碰到一個朋友乙,甲問了一句:哥們你吃飯了麼?

結果乙帶著耳機聽歌呢,根本沒聽到,沒反應。甲心裡想:跟你說話也沒個音,不跟你說了,溝通失敗。說明乙接受不到甲傳過來的資訊的情況下溝通肯定是失敗的。

如果乙聽到了甲說的話,那麼第一次對話成功,接下來進行第二次對話。

第二次對話:

乙聽到了甲說的話,但是他是老外,中文不好,不知道甲說的啥意思也不知道怎樣回答,於是隨便回答了一句學過的中文 :我去廁所了。甲一聽立刻笑噴了,“去廁所吃飯”?道不同不相為謀,離你遠點吧,溝通失敗。說明乙無法做出正確應答的情況下溝通失敗。

如果乙聽到了甲的話,做出了正確的應答,並且還進行了反問:我吃飯了,你呢?那麼第二次握手成功。

透過前兩次對話證明了乙能夠聽懂甲說的話,並且能做出正確的應答。接下來進行第三次對話。

第三次對話:

甲剛和乙打了個招呼,突然老婆喊他,“你個死鬼,打個醬油咋這麼半天,看我回家咋收拾你”,甲是個妻管嚴,聽完嚇得二話不說就跑回家了,把乙自己晾那了。乙心想:這什麼人啊,得,我也回家吧,溝通失敗。說明甲無法做出應答的情況下溝通失敗。

如果甲也做出了正確的應答:我也吃了。那麼第三次對話成功,兩人已經建立起了順暢的溝通渠道,接下來開始持續的聊天。

透過第二次和第三次的對話證明了甲能夠聽懂乙說的話,並且能做出正確的應答。

可見,兩個人進行有效的語言溝通,這三次對話的過程是必須的。

同理對於TCP為什麼需要進行三次握手我們可以一樣的理解:

為了保證服務端能收接受到客戶端的資訊並能做出正確的應答而進行前兩次(第一次和第二次)握手,為了保證客戶端能夠接收到服務端的資訊並能做出正確的應答而進行後兩次(第二次和第三次)握手。

當然,還有一種更通俗的~

買手機的時候試通話功能的時候:

  1. 老機打給新機 : 喂 , 聽到了嗎 ?

  2. 新機回覆老機 : 聽到了 , 你聽到了嗎 ?

  3. 老機 : 聽到了聽到了 …

驗證通話功能OK !


·END·

程式設計師的成長之路

路雖遠,行則必至。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4662/viewspace-2822309/,如需轉載,請註明出處,否則將追究法律責任。

相關文章