TCP 為什么是三次握手四次揮手?

簡(jiǎn)介

TCP 三次握手四次揮手

我們都知道 TCP 有建立連接時(shí)的三次握手斷開連接時(shí)的四次揮手钩述,如上圖所示吊趾。這個(gè)過(guò)程具體怎么樣就不多說(shuō)了宛裕。
今天主要想討論一下,為什么 TCP 是三次握手论泛,四次揮手揩尸。
下面說(shuō)說(shuō)個(gè)人對(duì)這個(gè)問題的理解和總結(jié)。

三次握手

初始化 Seq

首先屁奏,TCP 的定位是全雙工的岩榆、支持半關(guān)閉的、可靠的傳輸協(xié)議。但是勇边,我們知道犹撒,網(wǎng)絡(luò)信道是不可靠的,隨時(shí)都有可能丟包粒褒、錯(cuò)包识颊、亂序。TCP 怎么在不可靠的網(wǎng)絡(luò)上實(shí)現(xiàn)可靠的傳輸協(xié)議呢奕坟?

對(duì)于丟包祥款,TCP 的解決方案很簡(jiǎn)單,就是超時(shí)重傳执赡。
對(duì)于錯(cuò)包镰踏,TCP 通過(guò)檢查出錯(cuò)誤后直接丟棄(丟包)。

所以問題來(lái)了沙合,TCP 怎么知道哪些包需要重傳呢?TCP 又是怎么解決包亂序到達(dá)的問題呢跌帐?
這兩個(gè)問題都是通過(guò) seq 來(lái)實(shí)現(xiàn)的首懈,三次握手的過(guò)程就是雙方協(xié)商好初始的 seq。

解決亂序:通過(guò) seq 確定順序谨敛。
確定重傳: 接收方在 ACK 里帶上 seq 告訴發(fā)送方收到了哪些數(shù)據(jù)包究履。發(fā)送方超時(shí)就重發(fā)沒收到 ACK 的包。

通信雙方協(xié)商好一個(gè)初始 seq脸狸,至少需要一次 SYN 和 一次 ACK最仑。


一次 seq 確認(rèn)

由于 TCP 是全雙工的,所以 TCP 要協(xié)商兩個(gè)初始 seq炊甲,所以雙方各需要一次 SYN 和一次 ACK泥彤。

兩次 seq 確認(rèn)

簡(jiǎn)單優(yōu)化,可以將中間的 ACK + SYN 合并卿啡。所以就變成了 TCP 建立連接的三次握手吟吝。


三次握手

確認(rèn)全雙工信道

另外還有一點(diǎn)就是,由于網(wǎng)絡(luò)信道是不可靠的颈娜,通過(guò)三次握手剑逃,可以最低限度地確定雙方的信息是雙向可用的(全雙工)。

假設(shè)是 A 向 B 發(fā)起請(qǐng)求官辽。
第二次握手成功表明 A => B 沒問題蛹磺。
第三次握手成功表明 B => A 沒問題。

四次揮手

理解了三次握手同仆,四次揮手就不難理解了萤捆。上面講到,三次握手其實(shí)是由“四次握手”合并二、三次握手優(yōu)化而來(lái)的鳖轰。那為什么第二次揮手和第三次揮手不能像握手協(xié)議中進(jìn)行合并呢清酥?

原因是: TCP 要支持半關(guān)閉連接

一開始建立的連接是全雙工的蕴侣,A <=> B 雙方都可以讀寫焰轻。支持半關(guān)閉意味著,TCP 支持 A 和 B 雙方獨(dú)立關(guān)閉通道昆雀。因此會(huì)有兩次獨(dú)立的關(guān)閉寫通道的請(qǐng)求辱志。一次關(guān)閉請(qǐng)求(FIN),對(duì)應(yīng)一個(gè) ACK狞膘。所以就有了四次揮手揩懒。


TCP 四次揮手

小結(jié)

TCP 需要三次握手的原因:

  1. 初始化雙方 seq。
  2. 確認(rèn)雙方信道可以實(shí)現(xiàn)最低限度的全雙工挽封。

TCP 需要四次揮手的原因:

  1. TCP 要支持半關(guān)閉連接已球。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市辅愿,隨后出現(xiàn)的幾起案子智亮,更是在濱河造成了極大的恐慌,老刑警劉巖点待,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阔蛉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡癞埠,警方通過(guò)查閱死者的電腦和手機(jī)状原,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)苗踪,“玉大人颠区,你說(shuō)我怎么就攤上這事⊥教剑” “怎么了瓦呼?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)测暗。 經(jīng)常有香客問我央串,道長(zhǎng),這世上最難降的妖魔是什么碗啄? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任质和,我火速辦了婚禮,結(jié)果婚禮上稚字,老公的妹妹穿的比我還像新娘饲宿。我一直安慰自己厦酬,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布瘫想。 她就那樣靜靜地躺著仗阅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪国夜。 梳的紋絲不亂的頭發(fā)上减噪,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音车吹,去河邊找鬼筹裕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛窄驹,可吹牛的內(nèi)容都是我干的朝卒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼乐埠,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼抗斤!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起丈咐,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤豪治,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后扯罐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡烦衣,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年歹河,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片花吟。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秸歧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出衅澈,到底是詐尸還是另有隱情键菱,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布今布,位于F島的核電站经备,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏部默。R本人自食惡果不足惜侵蒙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望傅蹂。 院中可真熱鬧纷闺,春花似錦算凿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至浸卦,卻和暖如春署鸡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背镐躲。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工储玫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人萤皂。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓撒穷,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親裆熙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子端礼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容