常見面試題
【問題1】為什么連接的時候是三次握手,關(guān)閉的時候卻是四次握手?
答:因為當(dāng)Server端收到Client端的SYN連接請求報文后,可以直接發(fā)送SYN+ACK報文舌狗。其中ACK報文是用來應(yīng)答的,SYN報文是用來同步的扔水。但是關(guān)閉連接時把夸,當(dāng)Server端收到FIN報文時,很可能并不會立即關(guān)閉SOCKET铭污,所以只能先回復(fù)一個ACK報文恋日,告訴Client端,"你發(fā)的FIN報文我收到了"嘹狞。只有等到我Server端所有的報文都發(fā)送完了岂膳,我才能發(fā)送FIN報文,因此不能一起發(fā)送磅网。故需要四步握手谈截。
【問題2】為什么TIME_WAIT狀態(tài)需要經(jīng)過2MSL(最大報文段生存時間)才能返回到CLOSE狀態(tài)?
答:雖然按道理涧偷,四個報文都發(fā)送完畢簸喂,我們可以直接進入CLOSE狀態(tài)了,但是我們必須假象網(wǎng)絡(luò)是不可靠的燎潮,有可以最后一個ACK丟失喻鳄。所以TIME_WAIT狀態(tài)就是用來重發(fā)可能丟失的ACK報文。在Client發(fā)送出最后的ACK回復(fù)确封,但該ACK可能丟失除呵。Server如果沒有收到ACK再菊,將不斷重復(fù)發(fā)送FIN片段。所以Client不能立即關(guān)閉颜曾,它必須確認(rèn)Server接收到了該ACK纠拔。Client會在發(fā)送出ACK之后進入到TIME_WAIT狀態(tài)。Client會設(shè)置一個計時器泛豪,等待2MSL的時間稠诲。如果在該時間內(nèi)再次收到FIN,那么Client會重發(fā)ACK并再次等待2MSL诡曙。所謂的2MSL是兩倍的MSL(Maximum Segment Lifetime)臀叙。MSL指一個片段在網(wǎng)絡(luò)中最大的存活時間,2MSL就是一個發(fā)送和一個回復(fù)所需的最大時間岗仑。如果直到2MSL,Client都沒有再次收到FIN聚请,那么Client推斷ACK已經(jīng)被成功接收荠雕,則結(jié)束TCP連接。
【問題3】為什么不能用兩次握手進行連接驶赏?
答:3次握手完成兩個重要的功能炸卑,既要雙方做好發(fā)送數(shù)據(jù)的準(zhǔn)備工作(雙方都知道彼此已準(zhǔn)備好),也要允許雙方就初始序列號進行協(xié)商煤傍,這個序列號在握手過程中被發(fā)送和確認(rèn)盖文。
? ? ? 現(xiàn)在把三次握手改成僅需要兩次握手,死鎖是可能發(fā)生的蚯姆。作為例子五续,考慮計算機S和C之間的通信,假定C給S發(fā)送一個連接請求分組龄恋,S收到了這個分組疙驾,并發(fā) 送了確認(rèn)應(yīng)答分組。按照兩次握手的協(xié)定郭毕,S認(rèn)為連接已經(jīng)成功地建立了它碎,可以開始發(fā)送數(shù)據(jù)分組∠匝海可是扳肛,C在S的應(yīng)答分組在傳輸中被丟失的情況下,將不知道S 是否已準(zhǔn)備好乘碑,不知道S建立什么樣的序列號挖息,C甚至懷疑S是否收到自己的連接請求分組。在這種情況下兽肤,C認(rèn)為連接還未建立成功旋讹,將忽略S發(fā)來的任何數(shù)據(jù)分 組殖蚕,只等待連接確認(rèn)應(yīng)答分組。而S在發(fā)出的分組超時后沉迹,重復(fù)發(fā)送同樣的分組睦疫。這樣就形成了死鎖。
【問題4】如果已經(jīng)建立了連接鞭呕,但是客戶端突然出現(xiàn)故障了怎么辦蛤育?
答:TCP還設(shè)有一個保活計時器葫松,顯然瓦糕,客戶端如果出現(xiàn)故障,服務(wù)器不能一直等下去腋么,白白浪費資源咕娄。服務(wù)器每收到一次客戶端的請求后都會重新復(fù)位這個計時器,時間通常是設(shè)置為2小時珊擂,若兩小時還沒有收到客戶端的任何數(shù)據(jù)圣勒,服務(wù)器就會發(fā)送一個探測報文段,以后每隔75分鐘發(fā)送一次摧扇。若一連發(fā)送10個探測報文仍然沒反應(yīng)圣贸,服務(wù)器就認(rèn)為客戶端出了故障,接著就關(guān)閉連接扛稽。
BTC地址:17ZcbhMvtob6xDvbKZvm4uLKnLJwkYxzH5
作者:我是李小胖
鏈接:http://www.reibang.com/p/b8a3dde775cd
來源:簡書
簡書著作權(quán)歸作者所有吁峻,任何形式的轉(zhuǎn)載都請聯(lián)系作者獲得授權(quán)并注明出處。