TCP的三次握手與四次揮手理解及面試題(很全面)

?序列號(hào)seq:占4個(gè)字節(jié)掌测,用來(lái)標(biāo)記數(shù)據(jù)段的順序内贮,TCP把連接中發(fā)送的所有數(shù)據(jù)字節(jié)都編上一個(gè)序號(hào),第一個(gè)字節(jié)的編號(hào)由本地隨機(jī)產(chǎn)生汞斧;給字節(jié)編上序號(hào)后夜郁,就給每一個(gè)報(bào)文段指派一個(gè)序號(hào);序列號(hào)seq就是這個(gè)報(bào)文段中的第一個(gè)字節(jié)的數(shù)據(jù)編號(hào)粘勒。

????確認(rèn)號(hào)ack:占4個(gè)字節(jié)竞端,期待收到對(duì)方下一個(gè)報(bào)文段的第一個(gè)數(shù)據(jù)字節(jié)的序號(hào);序列號(hào)表示報(bào)文段攜帶數(shù)據(jù)的第一個(gè)字節(jié)的編號(hào)庙睡;而確認(rèn)號(hào)指的是期望接收到下一個(gè)字節(jié)的編號(hào)事富;因此當(dāng)前報(bào)文段最后一個(gè)字節(jié)的編號(hào)+1即為確認(rèn)號(hào)。

????確認(rèn)ACK:占1位乘陪,僅當(dāng)ACK=1時(shí)统台,確認(rèn)號(hào)字段才有效。ACK=0時(shí)啡邑,確認(rèn)號(hào)無(wú)效

????同步SYN:連接建立時(shí)用于同步序號(hào)贱勃。當(dāng)SYN=1,ACK=0時(shí)表示:這是一個(gè)連接請(qǐng)求報(bào)文段谤逼。若同意連接贵扰,則在響應(yīng)報(bào)文段中使得SYN=1,ACK=1流部。因此戚绕,SYN=1表示這是一個(gè)連接請(qǐng)求,或連接接受報(bào)文枝冀。SYN這個(gè)標(biāo)志位只有在TCP建產(chǎn)連接時(shí)才會(huì)被置1舞丛,握手完成后SYN標(biāo)志位被置0。

????終止FIN:用來(lái)釋放一個(gè)連接宾茂。FIN=1表示:此報(bào)文段的發(fā)送方的數(shù)據(jù)已經(jīng)發(fā)送完畢瓷马,并要求釋放運(yùn)輸連接

????PS:ACK拴还、SYN和FIN這些大寫(xiě)的單詞表示標(biāo)志位跨晴,其值要么是1,要么是0片林;ack端盆、seq小寫(xiě)的單詞表示序號(hào)怀骤。



三次握手過(guò)程理解

第一次握手:建立連接時(shí),客戶端發(fā)送syn包(syn=j)到服務(wù)器焕妙,并進(jìn)入SYN_SENT狀態(tài)蒋伦,等待服務(wù)器確認(rèn);SYN:同步序列編號(hào)(Synchronize Sequence Numbers)焚鹊。

第二次握手:服務(wù)器收到syn包痕届,必須確認(rèn)客戶的SYN(ack=j+1),同時(shí)自己也發(fā)送一個(gè)SYN包(syn=k)末患,即SYN+ACK包研叫,此時(shí)服務(wù)器進(jìn)入SYN_RECV狀態(tài);

第三次握手:客戶端收到服務(wù)器的SYN+ACK包璧针,向服務(wù)器發(fā)送確認(rèn)包ACK(ack=k+1)嚷炉,此包發(fā)送完畢,客戶端和服務(wù)器進(jìn)入ESTABLISHED(TCP連接成功)狀態(tài)探橱,完成三次握手申屹。

四次揮手過(guò)程理解?


1)客戶端進(jìn)程發(fā)出連接釋放報(bào)文,并且停止發(fā)送數(shù)據(jù)隧膏。釋放數(shù)據(jù)報(bào)文首部哗讥,F(xiàn)IN=1,其序列號(hào)為seq=u(等于前面已經(jīng)傳送過(guò)來(lái)的數(shù)據(jù)的最后一個(gè)字節(jié)的序號(hào)加1)胞枕,此時(shí)忌栅,客戶端進(jìn)入FIN-WAIT-1(終止等待1)狀態(tài)。 TCP規(guī)定曲稼,F(xiàn)IN報(bào)文段即使不攜帶數(shù)據(jù)索绪,也要消耗一個(gè)序號(hào)。

2)服務(wù)器收到連接釋放報(bào)文贫悄,發(fā)出確認(rèn)報(bào)文瑞驱,ACK=1,ack=u+1窄坦,并且?guī)献约旱男蛄刑?hào)seq=v唤反,此時(shí),服務(wù)端就進(jìn)入了CLOSE-WAIT(關(guān)閉等待)狀態(tài)鸭津。TCP服務(wù)器通知高層的應(yīng)用進(jìn)程彤侍,客戶端向服務(wù)器的方向就釋放了账磺,這時(shí)候處于半關(guān)閉狀態(tài)食拜,即客戶端已經(jīng)沒(méi)有數(shù)據(jù)要發(fā)送了,但是服務(wù)器若發(fā)送數(shù)據(jù)绪氛,客戶端依然要接受闻书。這個(gè)狀態(tài)還要持續(xù)一段時(shí)間名斟,也就是整個(gè)CLOSE-WAIT狀態(tài)持續(xù)的時(shí)間脑慧。

3)客戶端收到服務(wù)器的確認(rèn)請(qǐng)求后,此時(shí)砰盐,客戶端就進(jìn)入FIN-WAIT-2(終止等待2)狀態(tài)闷袒,等待服務(wù)器發(fā)送連接釋放報(bào)文(在這之前還需要接受服務(wù)器發(fā)送的最后的數(shù)據(jù))。

4)服務(wù)器將最后的數(shù)據(jù)發(fā)送完畢后岩梳,就向客戶端發(fā)送連接釋放報(bào)文囊骤,F(xiàn)IN=1,ack=u+1冀值,由于在半關(guān)閉狀態(tài)淘捡,服務(wù)器很可能又發(fā)送了一些數(shù)據(jù),假定此時(shí)的序列號(hào)為seq=w池摧,此時(shí)焦除,服務(wù)器就進(jìn)入了LAST-ACK(最后確認(rèn))狀態(tài),等待客戶端的確認(rèn)作彤。

5)客戶端收到服務(wù)器的連接釋放報(bào)文后膘魄,必須發(fā)出確認(rèn),ACK=1竭讳,ack=w+1创葡,而自己的序列號(hào)是seq=u+1,此時(shí)绢慢,客戶端就進(jìn)入了TIME-WAIT(時(shí)間等待)狀態(tài)灿渴。注意此時(shí)TCP連接還沒(méi)有釋放,必須經(jīng)過(guò)2??MSL(最長(zhǎng)報(bào)文段壽命)的時(shí)間后胰舆,當(dāng)客戶端撤銷(xiāo)相應(yīng)的TCB后骚露,才進(jìn)入CLOSED狀態(tài)。

6)服務(wù)器只要收到了客戶端發(fā)出的確認(rèn)缚窿,立即進(jìn)入CLOSED狀態(tài)棘幸。同樣,撤銷(xiāo)TCB后倦零,就結(jié)束了這次的TCP連接误续。可以看到扫茅,服務(wù)器結(jié)束TCP連接的時(shí)間要比客戶端早一些蹋嵌。

常見(jiàn)面試題

【問(wèn)題1】為什么連接的時(shí)候是三次握手,關(guān)閉的時(shí)候卻是四次握手葫隙?

答:因?yàn)楫?dāng)Server端收到Client端的SYN連接請(qǐng)求報(bào)文后栽烂,可以直接發(fā)送SYN+ACK報(bào)文。其中ACK報(bào)文是用來(lái)應(yīng)答的,SYN報(bào)文是用來(lái)同步的愕鼓。但是關(guān)閉連接時(shí)钙态,當(dāng)Server端收到FIN報(bào)文時(shí)慧起,很可能并不會(huì)立即關(guān)閉SOCKET菇晃,所以只能先回復(fù)一個(gè)ACK報(bào)文,告訴Client端蚓挤,"你發(fā)的FIN報(bào)文我收到了"磺送。只有等到我Server端所有的報(bào)文都發(fā)送完了,我才能發(fā)送FIN報(bào)文灿意,因此不能一起發(fā)送估灿。故需要四步握手。

【問(wèn)題2】為什么TIME_WAIT狀態(tài)需要經(jīng)過(guò)2MSL(最大報(bào)文段生存時(shí)間)才能返回到CLOSE狀態(tài)缤剧?

答:雖然按道理馅袁,四個(gè)報(bào)文都發(fā)送完畢,我們可以直接進(jìn)入CLOSE狀態(tài)了荒辕,但是我們必須假象網(wǎng)絡(luò)是不可靠的汗销,有可以最后一個(gè)ACK丟失。所以TIME_WAIT狀態(tài)就是用來(lái)重發(fā)可能丟失的ACK報(bào)文抵窒。在Client發(fā)送出最后的ACK回復(fù)弛针,但該ACK可能丟失。Server如果沒(méi)有收到ACK李皇,將不斷重復(fù)發(fā)送FIN片段削茁。所以Client不能立即關(guān)閉,它必須確認(rèn)Server接收到了該ACK掉房。Client會(huì)在發(fā)送出ACK之后進(jìn)入到TIME_WAIT狀態(tài)茧跋。Client會(huì)設(shè)置一個(gè)計(jì)時(shí)器,等待2MSL的時(shí)間卓囚。如果在該時(shí)間內(nèi)再次收到FIN厌衔,那么Client會(huì)重發(fā)ACK并再次等待2MSL。所謂的2MSL是兩倍的MSL(Maximum Segment Lifetime)捍岳。MSL指一個(gè)片段在網(wǎng)絡(luò)中最大的存活時(shí)間富寿,2MSL就是一個(gè)發(fā)送和一個(gè)回復(fù)所需的最大時(shí)間。如果直到2MSL锣夹,Client都沒(méi)有再次收到FIN页徐,那么Client推斷ACK已經(jīng)被成功接收,則結(jié)束TCP連接银萍。

【問(wèn)題3】為什么不能用兩次握手進(jìn)行連接变勇?

答:3次握手完成兩個(gè)重要的功能,既要雙方做好發(fā)送數(shù)據(jù)的準(zhǔn)備工作(雙方都知道彼此已準(zhǔn)備好),也要允許雙方就初始序列號(hào)進(jìn)行協(xié)商搀绣,這個(gè)序列號(hào)在握手過(guò)程中被發(fā)送和確認(rèn)飞袋。

???????現(xiàn)在把三次握手改成僅需要兩次握手,死鎖是可能發(fā)生的链患。作為例子巧鸭,考慮計(jì)算機(jī)S和C之間的通信,假定C給S發(fā)送一個(gè)連接請(qǐng)求分組麻捻,S收到了這個(gè)分組纲仍,并發(fā) 送了確認(rèn)應(yīng)答分組。按照兩次握手的協(xié)定贸毕,S認(rèn)為連接已經(jīng)成功地建立了郑叠,可以開(kāi)始發(fā)送數(shù)據(jù)分組∶鞴鳎可是乡革,C在S的應(yīng)答分組在傳輸中被丟失的情況下,將不知道S 是否已準(zhǔn)備好摊腋,不知道S建立什么樣的序列號(hào)沸版,C甚至懷疑S是否收到自己的連接請(qǐng)求分組。在這種情況下歌豺,C認(rèn)為連接還未建立成功推穷,將忽略S發(fā)來(lái)的任何數(shù)據(jù)分 組,只等待連接確認(rèn)應(yīng)答分組类咧。而S在發(fā)出的分組超時(shí)后馒铃,重復(fù)發(fā)送同樣的分組。這樣就形成了死鎖痕惋。

【問(wèn)題4】如果已經(jīng)建立了連接区宇,但是客戶端突然出現(xiàn)故障了怎么辦?

TCP還設(shè)有一個(gè)敝荡粒活計(jì)時(shí)器议谷,顯然,客戶端如果出現(xiàn)故障堕虹,服務(wù)器不能一直等下去卧晓,白白浪費(fèi)資源。服務(wù)器每收到一次客戶端的請(qǐng)求后都會(huì)重新復(fù)位這個(gè)計(jì)時(shí)器赴捞,時(shí)間通常是設(shè)置為2小時(shí)逼裆,若兩小時(shí)還沒(méi)有收到客戶端的任何數(shù)據(jù),服務(wù)器就會(huì)發(fā)送一個(gè)探測(cè)報(bào)文段赦政,以后每隔75秒鐘發(fā)送一次胜宇。若一連發(fā)送10個(gè)探測(cè)報(bào)文仍然沒(méi)反應(yīng),服務(wù)器就認(rèn)為客戶端出了故障,接著就關(guān)閉連接桐愉。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末财破,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子从诲,更是在濱河造成了極大的恐慌左痢,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盏求,死亡現(xiàn)場(chǎng)離奇詭異抖锥,居然都是意外死亡亿眠,警方通過(guò)查閱死者的電腦和手機(jī)碎罚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)纳像,“玉大人荆烈,你說(shuō)我怎么就攤上這事【怪海” “怎么了憔购?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)岔帽。 經(jīng)常有香客問(wèn)我玫鸟,道長(zhǎng),這世上最難降的妖魔是什么犀勒? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任屎飘,我火速辦了婚禮,結(jié)果婚禮上贾费,老公的妹妹穿的比我還像新娘钦购。我一直安慰自己,他們只是感情好褂萧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布押桃。 她就那樣靜靜地躺著,像睡著了一般导犹。 火紅的嫁衣襯著肌膚如雪唱凯。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,301評(píng)論 1 301
  • 那天谎痢,我揣著相機(jī)與錄音磕昼,去河邊找鬼。 笑死舶得,一個(gè)胖子當(dāng)著我的面吹牛掰烟,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼纫骑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蝎亚!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起先馆,我...
    開(kāi)封第一講書(shū)人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤发框,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后煤墙,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體梅惯,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年仿野,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了铣减。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脚作,死狀恐怖葫哗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情球涛,我是刑警寧澤劣针,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站亿扁,受9級(jí)特大地震影響捺典,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜从祝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一襟己、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧哄褒,春花似錦稀蟋、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至链嘀,卻和暖如春萌狂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背怀泊。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工茫藏, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人霹琼。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓务傲,卻偏偏與公主長(zhǎng)得像凉当,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子售葡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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

  • 本篇結(jié)構(gòu): 前言 TCP報(bào)文首部格式 三次握手 四次揮手 wireshark抓包三次握手 wireshark抓包四...
    w1992wishes閱讀 8,294評(píng)論 0 57
  • 三次握手和四次揮手是各個(gè)公司常見(jiàn)的考點(diǎn)挟伙,也具有一定的水平區(qū)分度楼雹,也被一些面試官作為熱身題。很多小伙伴說(shuō)這個(gè)問(wèn)題剛開(kāi)...
    猿人谷閱讀 440評(píng)論 0 6
  • 三次握手和四次揮手是各個(gè)公司常見(jiàn)的考點(diǎn)尖阔,也具有一定的水平區(qū)分度贮缅,也被一些面試官作為熱身題。很多同學(xué)這個(gè)問(wèn)題剛開(kāi)始回...
    二豬哥閱讀 623評(píng)論 0 6
  • 不知道什么時(shí)候開(kāi)始,我們想看朋友的動(dòng)態(tài)要往下滑個(gè)4-5下筷笨,越過(guò)成功雞湯憔鬼,穿過(guò)大批微商廣告龟劲,才能如愿胃夏。 更有網(wǎng)友吐槽...
    籃球發(fā)燒友圈閱讀 271評(píng)論 0 0
  • 1仰禀、數(shù)組1)、創(chuàng)建數(shù)組創(chuàng)建定長(zhǎng)數(shù)組和長(zhǎng)度可變數(shù)組 2)蚕愤、數(shù)組操作 3)答恶、遍歷數(shù)組使用for循環(huán)以及until好用的...
    數(shù)據(jù)萌新閱讀 186評(píng)論 0 0