TCP 傳輸連接管理
因?yàn)?TCP 三次握手建立連接、四次揮手釋放連接很重要,所以附上《計(jì)算機(jī)網(wǎng)絡(luò)(第 7 版)-謝希仁》書中對(duì)此章的詳細(xì)描述:https://gitee.com/huihut/interview/raw/master/images/TCP-transport-connection-management.png
TCP 三次握手建立連接
【TCP 建立連接全過程解釋】
客戶端發(fā)送 SYN 給服務(wù)器,說明客戶端請(qǐng)求建立連接;
服務(wù)端收到客戶端發(fā)的 SYN,并回復(fù) SYN+ACK 給客戶端(同意建立連接);
客戶端收到服務(wù)端的 SYN+ACK 后,回復(fù) ACK 給服務(wù)端(表示客戶端收到了服務(wù)端發(fā)的同意報(bào)文);
服務(wù)端收到客戶端的 ACK,連接已建立,可以數(shù)據(jù)傳輸。
TCP 為什么要進(jìn)行三次握手?
【答案一】因?yàn)樾诺啦豢煽浚?TCP 想在不可靠信道上建立可靠地傳輸,那么三次通信是理論上的最小值。(而 UDP 則不需建立可靠傳輸,因此 UDP 不需要三次握手。)
【答案二】因?yàn)殡p方都需要確認(rèn)對(duì)方收到了自己發(fā)送的序列號(hào),確認(rèn)過程最少要進(jìn)行三次通信。
【答案三】為了防止已失效的連接請(qǐng)求報(bào)文段突然又傳送到了服務(wù)端,因而產(chǎn)生錯(cuò)誤。
TCP 四次揮手釋放連接
【TCP 釋放連接全過程解釋】
客戶端發(fā)送 FIN 給服務(wù)器,說明客戶端不必發(fā)送數(shù)據(jù)給服務(wù)器了(請(qǐng)求釋放從客戶端到服務(wù)器的連接);
服務(wù)器接收到客戶端發(fā)的 FIN,并回復(fù) ACK 給客戶端(同意釋放從客戶端到服務(wù)器的連接);
客戶端收到服務(wù)端回復(fù)的 ACK,此時(shí)從客戶端到服務(wù)器的連接已釋放(但服務(wù)端到客戶端的連接還未釋放,并且客戶端還可以接收數(shù)據(jù));
服務(wù)端繼續(xù)發(fā)送之前沒發(fā)完的數(shù)據(jù)給客戶端;
服務(wù)端發(fā)送 FIN+ACK 給客戶端,說明服務(wù)端發(fā)送完了數(shù)據(jù)(請(qǐng)求釋放從服務(wù)端到客戶端的連接,就算沒收到客戶端的回復(fù),過段時(shí)間也會(huì)自動(dòng)釋放);
客戶端收到服務(wù)端的 FIN+ACK,并回復(fù) ACK 給客戶端(同意釋放從服務(wù)端到客戶端的連接);
服務(wù)端收到客戶端的 ACK 后,釋放從服務(wù)端到客戶端的連接。
TCP 為什么要進(jìn)行四次揮手?
【問題一】TCP 為什么要進(jìn)行四次揮手?/ 為什么 TCP 建立連接需要三次,而釋放連接則需要四次?
【答案一】因?yàn)?TCP 是全雙工模式,客戶端請(qǐng)求關(guān)閉連接后,客戶端向服務(wù)端的連接關(guān)閉(一二次揮手),服務(wù)端繼續(xù)傳輸之前沒傳完的數(shù)據(jù)給客戶端(數(shù)據(jù)傳輸),服務(wù)端向客戶端的連接關(guān)閉(三四次揮手)。所以 TCP 釋放連接時(shí)服務(wù)器的 ACK 和 FIN 是分開發(fā)送的(中間隔著數(shù)據(jù)傳輸),而 TCP 建立連接時(shí)服務(wù)器的 ACK 和 SYN 是一起發(fā)送的(第二次握手),所以 TCP 建立連接需要三次,而釋放連接則需要四次。
【問題二】為什么 TCP 連接時(shí)可以 ACK 和 SYN 一起發(fā)送,而釋放時(shí)則 ACK 和 FIN 分開發(fā)送呢?(ACK 和 FIN 分開是指第二次和第三次揮手)
【答案二】因?yàn)榭蛻舳苏?qǐng)求釋放時(shí),服務(wù)器可能還有數(shù)據(jù)需要傳輸給客戶端,因此服務(wù)端要先響應(yīng)客戶端 FIN 請(qǐng)求(服務(wù)端發(fā)送 ACK),然后數(shù)據(jù)傳輸,傳輸完成后,服務(wù)端再提出 FIN 請(qǐng)求(服務(wù)端發(fā)送 FIN);而連接時(shí)則沒有中間的數(shù)據(jù)傳輸,因此連接時(shí)可以 ACK 和 SYN 一起發(fā)送。
【問題三】為什么客戶端釋放最后需要 TIME-WAIT 等待 2MSL 呢?
【答案三】
(1)為了保證客戶端發(fā)送的最后一個(gè) ACK 報(bào)文能夠到達(dá)服務(wù)端。若未成功到達(dá),則服務(wù)端超時(shí)重傳 FIN+ACK 報(bào)文段,客戶端再重傳 ACK,并重新計(jì)時(shí)。
(2)防止已失效的連接請(qǐng)求報(bào)文段出現(xiàn)在本連接中。TIME-WAIT 持續(xù) 2MSL 可使本連接持續(xù)的時(shí)間內(nèi)所產(chǎn)生的所有報(bào)文段都從網(wǎng)絡(luò)中消失,這樣可使下次連接中不會(huì)出現(xiàn)舊的連接報(bào)文段。
TCP 有限狀態(tài)機(jī)
TCP 有限狀態(tài)機(jī)圖片
今天的分享就到這里了,大家要好好學(xué)C++喲~
編輯:jq
-
TCP
+關(guān)注
關(guān)注
8文章
1351瀏覽量
78989 -
C++
+關(guān)注
關(guān)注
22文章
2104瀏覽量
73498 -
服務(wù)端
+關(guān)注
關(guān)注
0文章
66瀏覽量
6987
原文標(biāo)題:C++基礎(chǔ)語法梳理:計(jì)算機(jī)網(wǎng)絡(luò)丨傳輸管理(TCP)
文章出處:【微信號(hào):cyuyanxuexi,微信公眾號(hào):C語言編程學(xué)習(xí)基地】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論