TCP可靠傳輸與擁塞控制

1.TCP的可靠傳輸

  • 確認(rèn)渗钉、超時(shí)重傳彤恶、報(bào)文排序

1.1 TCP如何保證可靠傳輸

發(fā)送方?jīng)]發(fā)送一個(gè)報(bào)文,都會(huì)收到來自接收方對該報(bào)文的確認(rèn)鳄橘,以確保數(shù)據(jù)被接收端接收声离;同時(shí)沒發(fā)一個(gè)報(bào)文會(huì)啟用一個(gè)超時(shí)重傳機(jī)制,若在規(guī)定時(shí)間內(nèi)發(fā)送方未接收到來自接收方的確認(rèn)報(bào)文瘫怜,那么就會(huì)認(rèn)為該報(bào)文在傳輸過程中丟失或在網(wǎng)絡(luò)中擁塞术徊,將重新發(fā)送這個(gè)數(shù)據(jù);接收方將收到的報(bào)文數(shù)據(jù)重新排序宝磨,保證數(shù)據(jù)有序弧关。

1.2 幾個(gè)基本概念

  • 發(fā)送緩存:發(fā)送方將可以發(fā)送給接收方的數(shù)據(jù)暫時(shí)存儲(chǔ)在發(fā)送緩存中
  • 發(fā)送窗口:已發(fā)送未確認(rèn)的數(shù)據(jù)+待發(fā)送的數(shù)據(jù)。發(fā)送窗口時(shí)發(fā)送緩存的一部分
  • 接收緩存:存放發(fā)送方傳輸?shù)奈吹玫酱_認(rèn)的數(shù)據(jù)以及未按序到達(dá)的數(shù)據(jù)
  • 接收窗口(通知窗口)—rwnd:接收方能夠接收數(shù)據(jù)的大小
  • 擁塞窗口—cwnd:擁塞窗口反映的是當(dāng)前網(wǎng)絡(luò)的擁塞程度

2.TCP的流量控制

  • 利用滑動(dòng)窗口進(jìn)行流量控制

2.1 流量控制原理

一般而言唤锉,發(fā)送窗口越大世囊,傳輸數(shù)據(jù)速度越快,但是這很容易造成網(wǎng)絡(luò)擁塞窿祥,因此需要?jiǎng)討B(tài)的改變發(fā)送窗口大小株憾,發(fā)送方發(fā)送窗口大小不應(yīng)該大于接收方接收窗口的大小。流量控制的作用就是讓發(fā)送方發(fā)送數(shù)據(jù)的速度不要太快晒衩,要讓接收方來得及接收所有的數(shù)據(jù)嗤瞎。

2.2 發(fā)送窗口如何改變

接收端發(fā)送的確認(rèn)報(bào)文中會(huì)將自己接收窗口的大小填入報(bào)文頭部窗口大小的位置中,發(fā)送方接收到確認(rèn)后听系,根據(jù)這個(gè)數(shù)據(jù)改變發(fā)送端窗口大小贝奇。若發(fā)送方的窗口大小為0,此時(shí)靠胜,接收端有收到報(bào)文掉瞳,也就是說,此時(shí)接收窗口大小不再是0浪漠,發(fā)送端繼續(xù)發(fā)送數(shù)據(jù)陕习。
考慮這樣的問題

2.3 流量控制和擁塞控制的關(guān)系

流量控制是點(diǎn)對點(diǎn)的控制,是端到端的問題址愿,旨在改變發(fā)送端發(fā)送窗口的大小该镣,控制發(fā)送數(shù)據(jù)的速率,以使接收端能夠來得及接受所有的數(shù)據(jù)响谓。
而擁塞控制是為了防止太多的數(shù)據(jù)傳輸在網(wǎng)絡(luò)中损合,擁塞控制是一個(gè)全局性的控制,必須保證當(dāng)前網(wǎng)絡(luò)能夠承受當(dāng)前的數(shù)據(jù)負(fù)載娘纷。若發(fā)送方在一定時(shí)間內(nèi)一直未接收到來自接收端的確認(rèn)信息塌忽,就會(huì)認(rèn)為網(wǎng)絡(luò)出現(xiàn)擁塞,但并不知道產(chǎn)生擁塞的原因失驶。

3.擁塞控制算法

  • 慢開始和擁塞避免土居、快重傳和快恢復(fù)

3.1慢開始算法和擁塞避免算法

  • 慢開始算法
    慢開始首先設(shè)置cwnd=1,發(fā)送方每接收到來自接收方的確認(rèn)報(bào)文就會(huì)將擁塞窗口增加1。每一次傳輸過程中嬉探,比如擦耀,發(fā)送發(fā)送4個(gè)報(bào)文段后,接收到來自接收方發(fā)送來的四個(gè)接收報(bào)文涩堤,將會(huì)對發(fā)送方擁塞窗口增加4眷蜓,那么每一次傳輸輪回,慢開始的過程會(huì)將發(fā)送方的擁塞窗口增加1倍胎围,即擁塞窗口呈指數(shù)級(jí)增長吁系。
  • 擁塞避免算法
    為防止擁塞窗口增長過大引起網(wǎng)絡(luò)擁塞德召,設(shè)置一個(gè)滿開始門限ssthresh,若當(dāng)前擁塞窗口值大于滿開始門限值時(shí)汽纤,減緩擁塞窗口增長速率上岗,從指數(shù)級(jí)增長改為線性增長,每個(gè)傳輸輪次僅增長1蕴坪,若網(wǎng)絡(luò)出現(xiàn)擁塞(即發(fā)送方?jīng)]有按時(shí)接收到來自接收方的確認(rèn)報(bào)文)肴掷,就將慢開始門限值設(shè)置為當(dāng)前擁塞窗口大小的一半,同時(shí)令擁塞窗口大小為1背传。

3.2 AIMD算法

  • “乘法減小”和“加法增大”(AIMD)算法
    擁塞避免階段呆瞻,每一個(gè)傳輸輪次,將擁塞窗口值加1径玖,增長速率比較慢痴脾,但能夠有效防止網(wǎng)絡(luò)出現(xiàn)擁塞。若網(wǎng)絡(luò)出現(xiàn)擁塞就將發(fā)送發(fā)慢開始門限值減半梳星,若網(wǎng)絡(luò)頻繁出現(xiàn)擁塞明郭,那么滿開始門限值的下降速率很快,這將極大程度的減小發(fā)送方發(fā)送到網(wǎng)絡(luò)中的數(shù)據(jù)

3.3 快重傳和快恢復(fù)

  • 快重傳
    在接收方收到亂序的報(bào)文時(shí)丰泊,立即發(fā)出一個(gè)重復(fù)確認(rèn)(即上一次有序的報(bào)文21)薯定,在接下來收到的報(bào)文中只要不是有序的報(bào)文21,都將立即重復(fù)發(fā)出一個(gè)確認(rèn)報(bào)文瞳购,以通知發(fā)送方報(bào)文未按序到達(dá)话侄。快重傳規(guī)定学赛,發(fā)送方若連續(xù)收到3個(gè)重復(fù)的報(bào)文年堆,應(yīng)立即重新發(fā)送對方未收到的數(shù)據(jù),而不必等待超時(shí)重傳時(shí)間的到達(dá)盏浇。
  • 快恢復(fù)
    若發(fā)送方連續(xù)收到來自接收端的3個(gè)重復(fù)確認(rèn)变丧,可知道此時(shí)網(wǎng)絡(luò)并沒有發(fā)生擁塞,但是為了防止擁塞绢掰,執(zhí)行“乘法減小”操作痒蓬,將慢開始門限值減半,但不執(zhí)行慢開始操作滴劲,即不將擁塞窗口大小設(shè)置為1攻晒,而是將擁塞窗口cwnd的值設(shè)置為ssthresh的一半,然后開始執(zhí)行擁塞避免算法(“加法增大”)
    采用快恢復(fù)算法時(shí)班挖,慢開始算法只在建立連接和網(wǎng)絡(luò)出現(xiàn)超時(shí)時(shí)使用
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鲁捏,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子萧芙,更是在濱河造成了極大的恐慌给梅,老刑警劉巖假丧,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異动羽,居然都是意外死亡包帚,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門曹质,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人擎场,你說我怎么就攤上這事羽德。” “怎么了迅办?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵宅静,是天一觀的道長。 經(jīng)常有香客問我站欺,道長姨夹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任矾策,我火速辦了婚禮磷账,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘贾虽。我一直安慰自己逃糟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布蓬豁。 她就那樣靜靜地躺著绰咽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪地粪。 梳的紋絲不亂的頭發(fā)上取募,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音蟆技,去河邊找鬼玩敏。 笑死,一個(gè)胖子當(dāng)著我的面吹牛质礼,可吹牛的內(nèi)容都是我干的聊品。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼几苍,長吁一口氣:“原來是場噩夢啊……” “哼翻屈!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起妻坝,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對情侶失蹤伸眶,失蹤者是張志新(化名)和其女友劉穎惊窖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體厘贼,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡界酒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嘴秸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片毁欣。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖岳掐,靈堂內(nèi)的尸體忽然破棺而出凭疮,到底是詐尸還是另有隱情,我是刑警寧澤串述,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布执解,位于F島的核電站,受9級(jí)特大地震影響纲酗,放射性物質(zhì)發(fā)生泄漏衰腌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一觅赊、第九天 我趴在偏房一處隱蔽的房頂上張望右蕊。 院中可真熱鬧,春花似錦吮螺、人聲如沸尤泽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽坯约。三九已至,卻和暖如春莫鸭,著一層夾襖步出監(jiān)牢的瞬間闹丐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國打工被因, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留卿拴,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓梨与,卻偏偏與公主長得像堕花,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子粥鞋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

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