TCP匙世#考

1. TCP和UDP的區(qū)別

用戶數(shù)據(jù)報(bào)協(xié)議 UDP(User Datagram Protocol)是無連接的,盡最大可能交付堤结,沒有擁塞控制唆迁,面向報(bào)文(對于應(yīng)用程序傳下來的報(bào)文不合并也不拆分,只是添加 UDP 首部)竞穷,支持一對一唐责、一對多、多對一和多對多的交互通信瘾带。
傳輸控制協(xié)議 TCP(Transmission Control Protocol)是面向連接的鼠哥,提供可靠交付,有流量控制看政,擁塞控制朴恳,提供全雙工通信,面向字節(jié)流(把應(yīng)用層傳下來的報(bào)文看成字節(jié)流允蚣,把字節(jié)流組織成大小不等的數(shù)據(jù)塊)于颖,每一條 TCP 連接只能是點(diǎn)對點(diǎn)的(一對一)。

UDP構(gòu)造可靠傳輸:加上必要的包頭字段:數(shù)據(jù)完整性 –> 加上一個(gè)16或者32位的CRC驗(yàn)證字段嚷兔; 亂序 –> 加上一個(gè)數(shù)據(jù)包序列號SEQ森渐; 丟包 –> 需要確認(rèn)和重傳機(jī)制,就是和Tcp類似的Ack機(jī)制冒晰;協(xié)議字段 –> protol 字段同衣,標(biāo)識當(dāng)前使用協(xié)議。

2. TCP頭部

序號:用于對字節(jié)流進(jìn)行編號壶运,例如序號為 301耐齐,表示第一個(gè)字節(jié)的編號為 301,如果攜帶的數(shù)據(jù)長度為 100 字節(jié),那么下一個(gè)報(bào)文段的序號應(yīng)為 401埠况。
確認(rèn)號 :期望收到的下一個(gè)報(bào)文段的序號耸携。
數(shù)據(jù)偏移 :指的是數(shù)據(jù)部分距離報(bào)文段起始處的偏移量,實(shí)際上指的是首部的長度询枚。
確認(rèn) ACK :當(dāng) ACK=1 時(shí)確認(rèn)號字段有效违帆,否則無效。TCP 規(guī)定金蜀,在連接建立后所有傳送的報(bào)文段都必須把 ACK 置 1刷后。
同步 SYN :在連接建立時(shí)用來同步序號。當(dāng) SYN=1渊抄,ACK=0 時(shí)表示這是一個(gè)連接請求報(bào)文段尝胆。若對方同意建立連接,則響應(yīng)報(bào)文中 SYN=1护桦,ACK=1含衔。
終止 FIN :用來釋放一個(gè)連接,當(dāng) FIN=1 時(shí)二庵,表示此報(bào)文段的發(fā)送方的數(shù)據(jù)已發(fā)送完畢贪染,并要求釋放連接。
窗口 :窗口值作為接收方讓發(fā)送方設(shè)置其發(fā)送窗口的依據(jù)催享。


3. 三次握手

  1. 服務(wù)器端處于LISTEN杭隙,客戶端處于CLOSED。
  2. 客戶端向服務(wù)器端發(fā)送請求連接報(bào)文段因妙,SYN=1痰憎,ACK=0,并選擇一個(gè)初始序號x攀涵。
  3. 服務(wù)器端若同意建立連接铣耘,向客戶端發(fā)送確認(rèn)報(bào)文段,SYN=1以故,ACK=1蜗细,確認(rèn)號x+1,并選擇一個(gè)初始序號y怒详。
  4. 客戶端收到確認(rèn)報(bào)文段后鳄乏,發(fā)送確認(rèn),確認(rèn)號問y+1棘利,序號為x+1。

第三次握手的原因朽缴?
客戶端發(fā)送的連接請求如果在網(wǎng)絡(luò)中滯留善玫,那么就會(huì)隔很長一段時(shí)間才能收到服務(wù)器端發(fā)回的連接確認(rèn)。客戶端等待一個(gè)超時(shí)重傳時(shí)間之后茅郎,就會(huì)重新請求連接蜗元。而失效的連接請求到達(dá)服務(wù)器,會(huì)讓服務(wù)器錯(cuò)誤打開連接系冗。

4.四次揮手

  1. 服務(wù)器端奕扣,客戶端處于ESTABLISHED。
  2. 客戶端發(fā)送一個(gè)連接釋放報(bào)文段掌敬,F(xiàn)IN=1惯豆。
  3. 服務(wù)器端發(fā)送確認(rèn),TCP處于半關(guān)閉狀態(tài)奔害】蓿客戶端仍可以接收數(shù)據(jù)。
  4. 當(dāng)服務(wù)器端不再需要連接的時(shí)候华临,發(fā)送連接釋放報(bào)文段芯杀,F(xiàn)IN=1。
  5. 客戶端收到去人雅潭,進(jìn)入TIME_WAIT(2MSL(最大報(bào)文存活時(shí)間))揭厚,然后釋放連接。
  6. 服務(wù)器端收到確認(rèn)后釋放連接扶供。

TIME_WAIT原因筛圆?
確保最后一個(gè)確認(rèn)報(bào)文能夠到達(dá)。如果 服務(wù)器端沒收到客戶端發(fā)送來的確認(rèn)報(bào)文诚欠,那么服務(wù)器端就會(huì)重新發(fā)送連接釋放請求報(bào)文顽染。
讓本連接持續(xù)時(shí)間內(nèi)所產(chǎn)生的所有報(bào)文都從網(wǎng)絡(luò)中消失,避免在新的連接中出現(xiàn)舊的報(bào)文轰绵。

5.實(shí)現(xiàn)可靠傳輸?

5.1超時(shí)重傳

如果一個(gè)已經(jīng)發(fā)送的報(bào)文段在超時(shí)時(shí)間(略大于RTT(報(bào)文段從發(fā)送再到接收到確認(rèn)所經(jīng)過的時(shí)間))內(nèi)沒有收到確認(rèn)粉寞,那么就重傳這個(gè)報(bào)文段。

5.2滑動(dòng)窗口

發(fā)送方和接收方各有一個(gè)窗口左腔,接收方通過 TCP 報(bào)文段中的窗口字段告訴發(fā)送方自己的窗口大小唧垦,發(fā)送方根據(jù)這個(gè)值和其它信息設(shè)置自己的窗口大小。
發(fā)送窗口內(nèi)的字節(jié)都允許被發(fā)送液样,接收窗口內(nèi)的字節(jié)都允許被接收振亮。如果發(fā)送窗口左部的字節(jié)已經(jīng)發(fā)送并且收到了確認(rèn)(接收窗口只會(huì)對窗口內(nèi)最后一個(gè)按序到達(dá)的字節(jié)進(jìn)行確認(rèn)),那么就滑動(dòng)窗口至第一個(gè)字節(jié)不是已發(fā)送且已確認(rèn)的狀態(tài)鞭莽。
接受方可以通過控制窗口大小來進(jìn)行流量控制坊秸。

5.2擁塞控制

cwnd為擁塞窗口,是一個(gè)狀態(tài)變量澎怒。
慢開始和擁塞避免
慢開始:cwnd=1褒搔,收到確認(rèn)后,cwnd加倍。并設(shè)置一個(gè)慢開始門限 ssthresh星瘾,當(dāng)cwnd >= ssthresh 時(shí)走孽,進(jìn)入擁塞避免。
擁塞避免:cwnd 每輪加 1琳状。
若出現(xiàn)了超時(shí)磕瓷,令ssthresh = cwnd / 2,重新執(zhí)行慢開始念逞。
快重傳與快恢復(fù)
在發(fā)送方困食,如果收到三個(gè)重復(fù)確認(rèn),那么可以知道下一個(gè)數(shù)據(jù)塊丟失肮柜,此時(shí)執(zhí)行快重傳陷舅,立即重傳下一個(gè)報(bào)文段。執(zhí)行快恢復(fù)审洞,令 ssthresh = cwnd / 2 莱睁,cwnd = ssthresh,此時(shí)直接進(jìn)入擁塞避免芒澜。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末仰剿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子痴晦,更是在濱河造成了極大的恐慌南吮,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件誊酌,死亡現(xiàn)場離奇詭異部凑,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)碧浊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門涂邀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人箱锐,你說我怎么就攤上這事比勉。” “怎么了驹止?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵浩聋,是天一觀的道長。 經(jīng)常有香客問我臊恋,道長衣洁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任抖仅,我火速辦了婚禮坊夫,結(jié)果婚禮上毙替,老公的妹妹穿的比我還像新娘。我一直安慰自己践樱,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布凸丸。 她就那樣靜靜地躺著拷邢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪屎慢。 梳的紋絲不亂的頭發(fā)上瞭稼,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天,我揣著相機(jī)與錄音腻惠,去河邊找鬼环肘。 笑死,一個(gè)胖子當(dāng)著我的面吹牛集灌,可吹牛的內(nèi)容都是我干的悔雹。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼欣喧,長吁一口氣:“原來是場噩夢啊……” “哼腌零!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起唆阿,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤益涧,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后驯鳖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體闲询,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年浅辙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了扭弧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,163評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡摔握,死狀恐怖寄狼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情氨淌,我是刑警寧澤泊愧,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站盛正,受9級特大地震影響删咱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜豪筝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一痰滋、第九天 我趴在偏房一處隱蔽的房頂上張望摘能。 院中可真熱鬧,春花似錦敲街、人聲如沸团搞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逻恐。三九已至,卻和暖如春峻黍,著一層夾襖步出監(jiān)牢的瞬間复隆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工姆涩, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留挽拂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓骨饿,卻偏偏與公主長得像亏栈,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子样刷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評論 2 344

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