TCP

TCP

TCP是一種面向連接的猜惋、可靠的折汞、基于字節(jié)流的傳輸層協(xié)議咒劲。在英特網(wǎng)協(xié)議中TCP位于IP層和應(yīng)用層之間。

* 功能

當(dāng)應(yīng)用層向TCP層發(fā)送用于網(wǎng)間傳輸?shù)臄?shù)據(jù)流的時(shí)候饲齐,TCP會(huì)把數(shù)據(jù)流分割成適當(dāng)長(zhǎng)度的報(bào)文段(最大傳輸段大小通常受該計(jì)算機(jī)連接的網(wǎng)絡(luò)的數(shù)據(jù)鏈路層的最大傳送單元限制)钉凌,之后TCP把數(shù)據(jù)包傳給IP層,用它來通過網(wǎng)絡(luò)把包傳送給接收端實(shí)體的TCP層

* 可靠性

為了保證報(bào)文傳輸?shù)目煽啃晕嫒耍琓CP會(huì)把每個(gè)包一個(gè)序號(hào)御雕,同時(shí)序號(hào)也保證了傳送到接收端實(shí)體的包的按序接收。接收端對(duì)已接收的包發(fā)回一個(gè)相應(yīng)的確認(rèn)(ACK)滥搭;如果發(fā)送端實(shí)體在合理的往返時(shí)延(RTT)內(nèi)未收到確認(rèn)饮笛,那么對(duì)應(yīng)的數(shù)據(jù)將會(huì)被重傳。

  • 在數(shù)據(jù)正確性與合法性上论熙,TCP用一個(gè)校驗(yàn)和函數(shù)來檢驗(yàn)數(shù)據(jù)是否有錯(cuò)誤,在發(fā)送和接收時(shí)都要計(jì)算校驗(yàn)和摄狱;同時(shí)可以使用md5認(rèn)證對(duì)數(shù)據(jù)進(jìn)行加密脓诡。
  • 在保證可靠性上,采用超時(shí)重傳和捎帶確認(rèn)機(jī)制媒役。
  • 在流量控制上祝谚,采用滑動(dòng)窗口 [1] 協(xié)議,協(xié)議中規(guī)定酣衷,對(duì)于窗口內(nèi)未經(jīng)確認(rèn)的分組需要重傳交惯。

* 連接建立

TCP是因特網(wǎng)中的傳輸層協(xié)議,使用三次握手協(xié)議建立連接穿仪。當(dāng)主動(dòng)發(fā)起SYN連接請(qǐng)求后席爽,等待對(duì)方回答SYN+ACK,并最終對(duì)對(duì)方的 SYN 執(zhí)行 ACK 確認(rèn)啊片。這種建立連接的方法可以防止產(chǎn)生錯(cuò)誤的連接只锻。

TCP三次握手的過程:
圖例:


TCP建立連接
  1. 客戶端發(fā)送SYN(SEQ=x)報(bào)文給服務(wù)器端,進(jìn)入SYN_SEND狀態(tài)紫谷。
  2. 服務(wù)器端收到SYN報(bào)文齐饮,回應(yīng)一個(gè)SYN (SEQ=y)ACK(ACK=x+1)報(bào)文捐寥,進(jìn)入SYN_RECV狀態(tài)。
  3. 客戶端收到服務(wù)器端的SYN報(bào)文祖驱,回應(yīng)一個(gè)ACK(ACK=y+1)報(bào)文握恳,進(jìn)入Established狀態(tài)。

(注:TCP規(guī)定, SYN報(bào)文段(SYN=1的報(bào)文段)不能攜帶數(shù)據(jù)捺僻,但需要消耗掉一個(gè)序號(hào)乡洼。)

三次握手完成,TCP客戶端和服務(wù)器端成功地建立連接陵像,可以開始傳輸數(shù)據(jù)了就珠。

* 連接終止

建立一個(gè)連接需要三次握手,而終止一個(gè)連接要經(jīng)過四次握手醒颖,這是由TCP的半關(guān)閉(half-close)造成的妻怎。
圖例:


TCP關(guān)閉連接
  1. 客戶端進(jìn)程發(fā)出連接釋放報(bào)文,并且停止發(fā)送數(shù)據(jù)泞歉。
    釋放數(shù)據(jù)報(bào)文首部逼侦,F(xiàn)IN=1,其序列號(hào)為seq=u(等于前面已經(jīng)傳送過來的數(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掖鱼,確認(rèn)序號(hào)為 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)沒有數(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齐莲,確認(rèn)序號(hào)為v+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,確認(rèn)序號(hào)為w+1盛泡,而自己的序列號(hào)是u+1闷祥,此時(shí),客戶端就進(jìn)入了TIME-WAIT(時(shí)間等待)狀態(tài)傲诵。注意此時(shí)TCP連接還沒有釋放凯砍,必須經(jīng)過2?MSL(最長(zhǎng)報(bào)文段壽命)的時(shí)間后,當(dāng)客戶端撤銷相應(yīng)的TCB后拴竹,才進(jìn)入CLOSED狀態(tài)悟衩。
  6. 服務(wù)器只要收到了客戶端發(fā)出的確認(rèn),立即進(jìn)入CLOSED狀態(tài)栓拜。同樣座泳,撤銷TCB后,就結(jié)束了這次的TCP連接幕与∏ィ可以看到,服務(wù)器結(jié)束TCP連接的時(shí)間要比客戶端早一些纽门。

為什么最后客戶端還要等待 2*MSL的時(shí)間呢?

  • MSL(Maximum Segment Lifetime),TCP允許不同的實(shí)現(xiàn)可以設(shè)置不同的MSL值营罢。
  • 第一赏陵,保證客戶端發(fā)送的最后一個(gè)ACK報(bào)文能夠到達(dá)服務(wù)器,因?yàn)檫@個(gè)ACK報(bào)文可能丟失饲漾,站在服務(wù)器的角度看來蝙搔,我已經(jīng)發(fā)送了FIN+ACK報(bào)文請(qǐng)求斷開了,客戶端還沒有給我回應(yīng)考传,應(yīng)該是我發(fā)送的請(qǐng)求斷開報(bào)文它沒有收到吃型,于是服務(wù)器又會(huì)重新發(fā)送一次,而客戶端就能在這個(gè)2MSL時(shí)間段內(nèi)收到這個(gè)重傳的報(bào)文僚楞,接著給出回應(yīng)報(bào)文勤晚,并且會(huì)重啟2MSL計(jì)時(shí)器枉层。
  • 第二,防止類似與“三次握手”中提到了的“已經(jīng)失效的連接請(qǐng)求報(bào)文段”出現(xiàn)在本連接中赐写∧窭客戶端發(fā)送完最后一個(gè)確認(rèn)報(bào)文后,在這個(gè)2MSL時(shí)間中挺邀,就可以使本連接持續(xù)的時(shí)間內(nèi)所產(chǎn)生的所有報(bào)文段都從網(wǎng)絡(luò)中消失揉忘。這樣新的連接中不會(huì)出現(xiàn)舊連接的請(qǐng)求報(bào)文。

為什么建立連接是三次握手端铛,關(guān)閉連接確是四次揮手呢泣矛?

  • 建立連接的時(shí)候, 服務(wù)器在LISTEN狀態(tài)下禾蚕,收到建立連接請(qǐng)求的SYN報(bào)文后您朽,把ACK和SYN放在一個(gè)報(bào)文里發(fā)送給客戶端。
    而關(guān)閉連接時(shí)夕膀,服務(wù)器收到對(duì)方的FIN報(bào)文時(shí)虚倒,僅僅表示對(duì)方不再發(fā)送數(shù)據(jù)了但是還能接收數(shù)據(jù),而自己也未必全部數(shù)據(jù)都發(fā)送給對(duì)方了产舞,所以己方可以立即關(guān)閉魂奥,也可以發(fā)送一些數(shù)據(jù)給對(duì)方后,再發(fā)送FIN報(bào)文給對(duì)方來表示同意現(xiàn)在關(guān)閉連接易猫,因此耻煤,己方ACK和FIN一般都會(huì)分開發(fā)送,從而導(dǎo)致多了一次准颓。
?著作權(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)離奇詭異吠勘,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)峡眶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門剧防,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人辫樱,你說我怎么就攤上這事峭拘。” “怎么了?”我有些...
    開封第一講書人閱讀 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)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼于游!你這毒婦竟也來了毁葱?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對(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
  • 我被黑心中介騙來泰國(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)容