日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 單片機(jī) > 架構(gòu)師社區(qū)
[導(dǎo)讀]三次握手兩次握手(情況1)兩次握手(情況2)OK,下面正經(jīng)地來回答下這個問題,要搞清楚這個問題,首先得了解TCP究竟是如何保證可靠傳輸?shù)?。PS:TCP協(xié)議中,主動發(fā)起請求的一端稱為『客戶端』,被動連接的一端稱為『服務(wù)端』。不管是客戶端還是服務(wù)端,TCP連接建立完后都能發(fā)送和接收數(shù)...

TCP?為什么是三次握手,而不是兩次或四次?



三次握手TCP?為什么是三次握手,而不是兩次或四次?



TCP?為什么是三次握手,而不是兩次或四次?


TCP?為什么是三次握手,而不是兩次或四次?



兩次握手(情況1)TCP?為什么是三次握手,而不是兩次或四次?



TCP?為什么是三次握手,而不是兩次或四次?



兩次握手(情況2)TCP?為什么是三次握手,而不是兩次或四次?



TCP?為什么是三次握手,而不是兩次或四次?



OK,下面正經(jīng)地來回答下這個問題,要搞清楚這個問題,首先得了解TCP究竟是如何保證可靠傳輸?shù)摹?br /> TCP?為什么是三次握手,而不是兩次或四次?



PS:TCP協(xié)議中,主動發(fā)起請求的一端稱為『客戶端』,被動連接的一端稱為『服務(wù)端』。不管是客戶端還是服務(wù)端,TCP連接建立完后都能發(fā)送和接收數(shù)據(jù)。
起初,服務(wù)器和客戶端都為CLOSED狀態(tài)。在通信開始前,雙方都得創(chuàng)建各自的傳輸控制塊(TCB)。服務(wù)器創(chuàng)建完TCB后遍進(jìn)入LISTEN狀態(tài),此時準(zhǔn)備接收客戶端發(fā)來的連接請求。
第一次握手
客戶端向服務(wù)端發(fā)送連接請求報文段。該報文段的頭部中SYN=1,ACK=0,seq=x。請求發(fā)送后,客戶端便進(jìn)入SYN-SENT狀態(tài)。
  • PS1:SYN=1,ACK=0表示該報文段為連接請求報文。


  • PS2:x為本次TCP通信的字節(jié)流的初始序號。TCP規(guī)定:SYN=1的報文段不能有數(shù)據(jù)部分,但要消耗掉一個序號。



第二次握手
服務(wù)端收到連接請求報文段后,如果同意連接,則會發(fā)送一個應(yīng)答:SYN=1,ACK=1,seq=y,ack=x 1。該應(yīng)答發(fā)送完成后便進(jìn)入SYN-RCVD狀態(tài)。
  • PS1:SYN=1,ACK=1表示該報文段為連接同意的應(yīng)答報文。


  • PS2:seq=y表示服務(wù)端作為發(fā)送者時,發(fā)送字節(jié)流的初始序號。


  • PS3:ack=x 1表示服務(wù)端希望下一個數(shù)據(jù)報發(fā)送序號從x 1開始的字節(jié)。



第三次握手
當(dāng)客戶端收到連接同意的應(yīng)答后,還要向服務(wù)端發(fā)送一個確認(rèn)報文段,表示:服務(wù)端發(fā)來的連接同意應(yīng)答已經(jīng)成功收到。該報文段的頭部為:ACK=1,seq=x 1,ack=y 1??蛻舳税l(fā)完這個報文段后便進(jìn)入ESTABLISHED狀態(tài),服務(wù)端收到這個應(yīng)答后也進(jìn)入ESTABLISHED狀態(tài),此時連接的建立完成!
為什么連接建立需要三次握手,而不是兩次握手?TCP?為什么是三次握手,而不是兩次或四次?



防止失效的連接請求報文段被服務(wù)端接收,從而產(chǎn)生錯誤。
PS:失效的連接請求:若客戶端向服務(wù)端發(fā)送的連接請求丟失,客戶端等待應(yīng)答超時后就會再次發(fā)送連接請求,此時,上一個連接請求就是『失效的』。
若建立連接只需兩次握手,客戶端并沒有太大的變化,仍然需要獲得服務(wù)端的應(yīng)答后才進(jìn)入ESTABLISHED狀態(tài),而服務(wù)端在收到連接請求后就進(jìn)入ESTABLISHED狀態(tài)。此時如果網(wǎng)絡(luò)擁塞,客戶端發(fā)送的連接請求遲遲到不了服務(wù)端,客戶端便超時重發(fā)請求,如果服務(wù)端正確接收并確認(rèn)應(yīng)答,雙方便開始通信,通信結(jié)束后釋放連接。此時,如果那個失效的連接請求抵達(dá)了服務(wù)端,由于只有兩次握手,服務(wù)端收到請求就會進(jìn)入ESTABLISHED狀態(tài),等待發(fā)送數(shù)據(jù)或主動發(fā)送數(shù)據(jù)。但此時的客戶端早已進(jìn)入CLOSED狀態(tài),服務(wù)端將會一直等待下去,這樣浪費服務(wù)端連接資源。


TCP四次揮手TCP?為什么是三次握手,而不是兩次或四次?



TCP?為什么是三次握手,而不是兩次或四次?



TCP連接的釋放一共需要四步,因此稱為『四次揮手』。
我們知道,TCP連接是雙向的,因此在四次揮手中,前兩次揮手用于斷開一個方向的連接,后兩次揮手用于斷開另一方向的連接。
第一次揮手
若A認(rèn)為數(shù)據(jù)發(fā)送完成,則它需要向B發(fā)送連接釋放請求。該請求只有報文頭,頭中攜帶的主要參數(shù)為:FIN=1,seq=u。此時,A將進(jìn)入FIN-WAIT-1狀態(tài)。
  • PS1:FIN=1表示該報文段是一個連接釋放請求。


  • PS2:seq=u,u-1是A向B發(fā)送的最后一個字節(jié)的序號。



第二次揮手
B收到連接釋放請求后,會通知相應(yīng)的應(yīng)用程序,告訴它A向B這個方向的連接已經(jīng)釋放。此時B進(jìn)入CLOSE-WAIT狀態(tài),并向A發(fā)送連接釋放的應(yīng)答,其報文頭包含:ACK=1,seq=v,ack=u 1。
  • PS1:ACK=1:除TCP連接請求報文段以外,TCP通信過程中所有數(shù)據(jù)報的ACK都為1,表示應(yīng)答。


  • PS2:seq=v,v-1是B向A發(fā)送的最后一個字節(jié)的序號。


  • PS3:ack=u 1表示希望收到從第u 1個字節(jié)開始的報文段,并且已經(jīng)成功接收了前u個字節(jié)。



A收到該應(yīng)答,進(jìn)入FIN-WAIT-2狀態(tài),等待B發(fā)送連接釋放請求。
第二次揮手完成后,A到B方向的連接已經(jīng)釋放,B不會再接收數(shù)據(jù),A也不會再發(fā)送數(shù)據(jù)。但B到A方向的連接仍然存在,B可以繼續(xù)向A發(fā)送數(shù)據(jù)。
第三次揮手
當(dāng)B向A發(fā)完所有數(shù)據(jù)后,向A發(fā)送連接釋放請求,請求頭:FIN=1,ACK=1,seq=w,ack=u 1。B便進(jìn)入LAST-ACK狀態(tài)。
第四次揮手
A收到釋放請求后,向B發(fā)送確認(rèn)應(yīng)答,此時A進(jìn)入TIME-WAIT狀態(tài)。該狀態(tài)會持續(xù)2MSL時間,若該時間段內(nèi)沒有B的重發(fā)請求的話,就進(jìn)入CLOSED狀態(tài),撤銷TCB。當(dāng)B收到確認(rèn)應(yīng)答后,也便進(jìn)入CLOSED狀態(tài),撤銷TCB。


為什么 A 要先進(jìn)入TIME-WAIT狀態(tài),等待2MSL時間后才進(jìn)入CLOSED狀態(tài)TCP?為什么是三次握手,而不是兩次或四次?



為了保證B能收到A的確認(rèn)應(yīng)答。若A發(fā)完確認(rèn)應(yīng)答后直接進(jìn)入CLOSED狀態(tài),那么如果該應(yīng)答丟失,B等待超時后就會重新發(fā)送連接釋放請求,但此時A已經(jīng)關(guān)閉了,不會作出任何響應(yīng),因此B永遠(yuǎn)無法正常關(guān)閉。



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

在資源受限的STM32微控制器上實現(xiàn)可靠的物聯(lián)網(wǎng)通信,需兼顧協(xié)議輕量化、內(nèi)存占用低和功耗優(yōu)化。本文以STM32F407(Cortex-M4內(nèi)核,192KB RAM)為例,提出“TCP基礎(chǔ)通信→MQTT協(xié)議適配→低功耗優(yōu)化...

關(guān)鍵字: TCP MQT

在工業(yè)自動化領(lǐng)域,Modbus協(xié)議憑借其開放性和易用性成為設(shè)備通信的"通用語言"。然而,當(dāng)工程師面對Modbus RTU、ASCII和TCP三種變體時,如何根據(jù)具體場景做出最優(yōu)選擇?本文將從編碼機(jī)制、通信效率、錯誤檢測等...

關(guān)鍵字: Modbus協(xié)議 TCP

TCP/IP(Transmission Control Protocol/Internet Protocol,傳輸控制協(xié)議/網(wǎng)際協(xié)議)是指能夠在多個不同網(wǎng)絡(luò)間實現(xiàn)信息傳輸?shù)膮f(xié)議簇。TCP/IP協(xié)議不僅僅指的是TCP 和I...

關(guān)鍵字: TCP IP

把TCP首部想象成一封信的信封,每個字段對應(yīng)信封上的不同信息。源端口和目的端口就像寄信人和收信人的門牌號,序列號和確認(rèn)號相當(dāng)于書信的頁碼編號和回執(zhí)編號。數(shù)據(jù)偏移量可以比作信封上留出的貼郵票位置,保留字段就像信封上預(yù)留的空...

關(guān)鍵字: TCP 首部信息

三次握手的目的,確保雙方都能正常通信,確認(rèn)雙方的發(fā)送和接收能力正常??赡芘e一個生活中的例子,比如打電話時的確認(rèn)過程。

關(guān)鍵字: TCP 通信

服務(wù)器接收請求是一個涉及網(wǎng)絡(luò)層(IP/端口綁定)、傳輸層(UDP/TCP/TLS 適配)、應(yīng)用層(SIP 協(xié)議解析)

關(guān)鍵字: 服務(wù)器 TCP UDP

在TCP(傳輸控制協(xié)議)網(wǎng)絡(luò)通信中,粘包問題一直是開發(fā)者需要面對和解決的難題。TCP粘包,即發(fā)送方多次寫入的數(shù)據(jù)在接收方被讀取時,多個數(shù)據(jù)包粘合在一起,導(dǎo)致接收方難以正確解析和處理數(shù)據(jù)。這種問題的出現(xiàn),主要源于TCP的傳...

關(guān)鍵字: TCP 粘包

TCP(Transmission Control Protocol,傳輸控制協(xié)議)是互聯(lián)網(wǎng)中廣泛使用的可靠傳輸協(xié)議,它通過三次握手過程來確保通信雙方能夠建立一個可靠的連接。然而,在復(fù)雜的網(wǎng)絡(luò)環(huán)境中,TCP三次握手過程可能...

關(guān)鍵字: TCP 傳輸控制協(xié)議

舊金山2024年7月22日 /美通社/ -- 百度國際旗下基于深度學(xué)習(xí)技術(shù)的智能廣告平臺MediaGo今天宣布,對平臺的SmartBid智能出價產(chǎn)品進(jìn)行全面升級,推出了最大轉(zhuǎn)化出價模式,旨在保證成本可控的同時,最大限度提...

關(guān)鍵字: MEDIA GO TCP PERFORMANCE

本次直播活動旨在紀(jì)念那些為現(xiàn)代互聯(lián)網(wǎng) 奠定基礎(chǔ)的發(fā)展 新澤西州皮斯卡特維2024年5月13日 /美通社/ -- 旨在通過推動技術(shù)進(jìn)步以造福人類的全球最大技術(shù)專業(yè)組...

關(guān)鍵字: IEEE 互聯(lián)網(wǎng) TCP GOOGLE
關(guān)閉