TCP/IP三次握手四次揮手常見面試題來源——oldboyedu李導

【問題1】為什么連接的時候是三次握手,關閉的時候卻是四次握手缓升?

答:因為當Server端收到Client端的SYN連接請求報文后咬最,可以直接發(fā)送SYN+ACK報文。其中ACK報文是用來應答的臀突,SYN報文是用來同步的勉抓。但是關閉連接時,當Server端收到FIN報文時候学,很可能并不會立即關閉SOCKET藕筋,所以只能先回復一個ACK報文,告訴Client端梳码,"你發(fā)的FIN報文我收到了"隐圾。只有等到我Server端所有的報文都發(fā)送完了,我才能發(fā)送FIN報文掰茶,因此不能一起發(fā)送暇藏。故需要四步握手。

三次握手a


四次揮手

【問題2】為什么TIME_WAIT狀態(tài)需要經(jīng)過2MSL(最大報文段生存時間)才能返回到CLOSE狀態(tài)符匾?

答:雖然按道理叨咖,四個報文都發(fā)送完畢,我們可以直接進入CLOSE狀態(tài)了啊胶,但是我們必須假象網(wǎng)絡是不可靠的甸各,有可以最后一個ACK丟失。所以TIME_WAIT狀態(tài)就是用來重發(fā)可能丟失的ACK報文焰坪。在Client發(fā)送出最后的ACK回復趣倾,但該ACK可能丟失。Server如果沒有收到ACK某饰,將不斷重復發(fā)送FIN片段儒恋。所以Client不能立即關閉,它必須確認Server接收到了該ACK黔漂。Client會在發(fā)送出ACK之后進入到TIME_WAIT狀態(tài)诫尽。Client會設置一個計時器,等待2MSL的時間炬守。如果在該時間內(nèi)再次收到FIN牧嫉,那么Client會重發(fā)ACK并再次等待2MSL。所謂的2MSL是兩倍的MSL(Maximum Segment Lifetime)。MSL指一個片段在網(wǎng)絡中最大的存活時間酣藻,2MSL就是一個發(fā)送和一個回復所需的最大時間曹洽。如果直到2MSL,Client都沒有再次收到FIN辽剧,那么Client推斷ACK已經(jīng)被成功接收送淆,則結束TCP連接。


【問題3】為什么不能用兩次握手進行連接怕轿?

答:3次握手完成兩個重要的功能偷崩,既要雙方做好發(fā)送數(shù)據(jù)的準備工作(雙方都知道彼此已準備好),也要允許雙方就初始序列號進行協(xié)商撤卢,這個序列號在握手過程中被發(fā)送和確認环凿。

? ? ? 現(xiàn)在把三次握手改成僅需要兩次握手,死鎖是可能發(fā)生的放吩。作為例子智听,考慮計算機S和C之間的通信,假定C給S發(fā)送一個連接請求分組渡紫,S收到了這個分組到推,并發(fā) 送了確認應答分組。按照兩次握手的協(xié)定惕澎,S認為連接已經(jīng)成功地建立了莉测,可以開始發(fā)送數(shù)據(jù)分組∵蠛恚可是捣卤,C在S的應答分組在傳輸中被丟失的情況下,將不知道S 是否已準備好八孝,不知道S建立什么樣的序列號董朝,C甚至懷疑S是否收到自己的連接請求分組。在這種情況下干跛,C認為連接還未建立成功子姜,將忽略S發(fā)來的任何數(shù)據(jù)分 組,只等待連接確認應答分組楼入。而S在發(fā)出的分組超時后哥捕,重復發(fā)送同樣的分組。這樣就形成了死鎖嘉熊。



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

答:TCP還設有一個辈簦活計時器鸽捻,顯然,客戶端如果出現(xiàn)故障,服務器不能一直等下去御蒲,白白浪費資源。服務器每收到一次客戶端的請求后都會重新復位這個計時器诊赊,時間通常是設置為2小時厚满,若兩小時還沒有收到客戶端的任何數(shù)據(jù),服務器就會發(fā)送一個探測報文段碧磅,以后每隔75分鐘發(fā)送一次碘箍。若一連發(fā)送10個探測報文仍然沒反應,服務器就認為客戶端出了故障鲸郊,接著就關閉連接丰榴。


最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市秆撮,隨后出現(xiàn)的幾起案子四濒,更是在濱河造成了極大的恐慌,老刑警劉巖职辨,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盗蟆,死亡現(xiàn)場離奇詭異,居然都是意外死亡舒裤,警方通過查閱死者的電腦和手機喳资,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來腾供,“玉大人仆邓,你說我怎么就攤上這事“楸睿” “怎么了节值?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長黎侈。 經(jīng)常有香客問我察署,道長,這世上最難降的妖魔是什么峻汉? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任贴汪,我火速辦了婚禮,結果婚禮上休吠,老公的妹妹穿的比我還像新娘扳埂。我一直安慰自己,他們只是感情好瘤礁,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布阳懂。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪岩调。 梳的紋絲不亂的頭發(fā)上巷燥,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天,我揣著相機與錄音号枕,去河邊找鬼缰揪。 笑死,一個胖子當著我的面吹牛葱淳,可吹牛的內(nèi)容都是我干的钝腺。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼赞厕,長吁一口氣:“原來是場噩夢啊……” “哼艳狐!你這毒婦竟也來了?” 一聲冷哼從身側響起皿桑,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤毫目,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后唁毒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蒜茴,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年浆西,在試婚紗的時候發(fā)現(xiàn)自己被綠了粉私。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡近零,死狀恐怖诺核,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情久信,我是刑警寧澤窖杀,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站裙士,受9級特大地震影響入客,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜腿椎,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一桌硫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧啃炸,春花似錦铆隘、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽掏湾。三九已至,卻和暖如春肿嘲,著一層夾襖步出監(jiān)牢的瞬間融击,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工雳窟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留砚嘴,地道東北人。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓涩拙,卻偏偏與公主長得像,于是被迫代替她去往敵國和親耸采。 傳聞我的和親對象是個殘疾皇子兴泥,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

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