18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

防止網絡擁塞現(xiàn)象的TCP擁塞控制算法

454398 ? 來源:博客園 ? 作者:海闊天空 ? 2020-10-29 14:54 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

為了防止網絡的擁塞現(xiàn)象,TCP提出了一系列的擁塞控制機制。最初由V.Jacobson在1988年的論文中提出的TCP的擁塞控制由“慢啟動(Slowstart)”和“擁塞避免(Congestionavoidance)”組成,后來TCPReno版本中又針對性的加入了“快速重傳(Fastretransmit)”、“快速恢復(FastRecovery)”算法,再后來在TCPNewReno中又對“快速恢復”算法進行了改進,近些年又出現(xiàn)了選擇性應答(selectiveacknowledgement,SACK)算法,還有其他方面的大大小小的改進,成為網絡研究的一個熱點。

TCP的擁塞控制主要原理依賴于一個擁塞窗口(cwnd)來控制,在之前我們還討論過TCP還有一個對端通告的接收窗口(rwnd)用于流量控制。窗口值的大小就代表能夠發(fā)送出去的但還沒有收到ACK的最大數(shù)據報文段,顯然窗口越大那么數(shù)據發(fā)送的速度也就越快,但是也有越可能使得網絡出現(xiàn)擁塞,如果窗口值為1,那么就簡化為一個停等協(xié)議,每發(fā)送一個數(shù)據,都要等到對方的確認才能發(fā)送第二個數(shù)據包,顯然數(shù)據傳輸效率低下。TCP的擁塞控制算法就是要在這兩者之間權衡,選取最好的cwnd值,從而使得網絡吞吐量最大化且不產生擁塞。

由于需要考慮擁塞控制和流量控制兩個方面的內容,因此TCP的真正的發(fā)送窗口=min(rwnd,cwnd)。但是rwnd是由對端確定的,網絡環(huán)境對其沒有影響,所以在考慮擁塞的時候我們一般不考慮rwnd的值,我們暫時只討論如何確定cwnd值的大小。關于cwnd的單位,在TCP中是以字節(jié)來做單位的,我們假設TCP每次傳輸都是按照MSS大小來發(fā)送數(shù)據的,因此你可以認為cwnd按照數(shù)據包個數(shù)來做單位也可以理解,所以有時我們說cwnd增加1也就是相當于字節(jié)數(shù)增加1個MSS大小。

慢啟動:最初的TCP在連接建立成功后會向網絡中發(fā)送大量的數(shù)據包,這樣很容易導致網絡中路由器緩存空間耗盡,從而發(fā)生擁塞。因此新建立的連接不能夠一開始就大量發(fā)送數(shù)據包,而只能根據網絡情況逐步增加每次發(fā)送的數(shù)據量,以避免上述現(xiàn)象的發(fā)生。具體來說,當新建連接時,cwnd初始化為1個最大報文段(MSS)大小,發(fā)送端開始按照擁塞窗口大小發(fā)送數(shù)據,每當有一個報文段被確認,cwnd就增加1個MSS大小。這樣cwnd的值就隨著網絡往返時間(RoundTripTime,RTT)呈指數(shù)級增長,事實上,慢啟動的速度一點也不慢,只是它的起點比較低一點而已。我們可以簡單計算下:

開始 --->cwnd=1

經過1個RTT后--->cwnd=2*1=2

經過2個RTT后---> cwnd=2*2=4

經過3個RTT后---> cwnd=4*2=8

如果帶寬為W,那么經過RTT*log2W時間就可以占滿帶寬。

擁塞避免:從慢啟動可以看到,cwnd可以很快的增長上來,從而最大程度利用網絡帶寬資源,但是cwnd不能一直這樣無限增長下去,一定需要某個限制。TCP使用了一個叫慢啟動門限(ssthresh)的變量,當cwnd超過該值后,慢啟動過程結束,進入擁塞避免階段。對于大多數(shù)TCP實現(xiàn)來說,ssthresh的值是65536(同樣以字節(jié)計算)。擁塞避免的主要思想是加法增大,也就是cwnd的值不再指數(shù)級往上升,開始加法增加。此時當窗口中所有的報文段都被確認時,cwnd的大小加1,cwnd的值就隨著RTT開始線性增加,這樣就可以避免增長過快導致網絡擁塞,慢慢的增加調整到網絡的最佳值。

上面討論的兩個機制都是沒有檢測到擁塞的情況下的行為,那么當發(fā)現(xiàn)擁塞了cwnd又該怎樣去調整呢?

首先來看TCP是如何確定網絡進入了擁塞狀態(tài)的,TCP認為網絡擁塞的主要依據是它重傳了一個報文段。上面提到過,TCP對每一個報文段都有一個定時器,稱為重傳定時器(RTO),當RTO超時且還沒有得到數(shù)據確認,那么TCP就會對該報文段進行重傳,當發(fā)生超時時,那么出現(xiàn)擁塞的可能性就很大,某個報文段可能在網絡中某處丟失,并且后續(xù)的報文段也沒有了消息,在這種情況下,TCP反應比較“強烈”:

1.把ssthresh降低為cwnd值的一半

2.把cwnd重新設置為1

3.重新進入慢啟動過程。

從整體上來講,TCP擁塞控制窗口變化的原則是AIMD原則,即加法增大、乘法減小??梢钥闯鯰CP的該原則可以較好地保證流之間的公平性,因為一旦出現(xiàn)丟包,那么立即減半退避,可以給其他新建的流留有足夠的空間,從而保證整個的公平性。

其實TCP還有一種情況會進行重傳:那就是收到3個相同的ACK。TCP在收到亂序到達包時就會立即發(fā)送ACK,TCP利用3個相同的ACK來判定數(shù)據包的丟失,此時進行快速重傳,快速重傳做的事情有:

1.把ssthresh設置為cwnd的一半

2.把cwnd再設置為ssthresh的值(具體實現(xiàn)有些為ssthresh+3)

3.重新進入擁塞避免階段。

后來的“快速恢復”算法是在上述的“快速重傳”算法后添加的,當收到3個重復ACK時,TCP最后進入的不是擁塞避免階段,而是快速恢復階段??焖僦貍骱涂焖倩謴退惴ㄒ话阃瑫r使用??焖倩謴偷乃枷胧恰皵?shù)據包守恒”原則,即同一個時刻在網絡中的數(shù)據包數(shù)量是恒定的,只有當“老”數(shù)據包離開了網絡后,才能向網絡中發(fā)送一個“新”的數(shù)據包,如果發(fā)送方收到一個重復的ACK,那么根據TCP的ACK機制就表明有一個數(shù)據包離開了網絡,于是cwnd加1。如果能夠嚴格按照該原則那么網絡中很少會發(fā)生擁塞,事實上擁塞控制的目的也就在修正違反該原則的地方。

具體來說快速恢復的主要步驟是:

1.當收到3個重復ACK時,把ssthresh設置為cwnd的一半,把cwnd設置為ssthresh的值加3,然后重傳丟失的報文段,加3的原因是因為收到3個重復的ACK,表明有3個“老”的數(shù)據包離開了網絡。

2.再收到重復的ACK時,擁塞窗口增加1。

3.當收到新的數(shù)據包的ACK時,把cwnd設置為第一步中的ssthresh的值。原因是因為該ACK確認了新的數(shù)據,說明從重復ACK時的數(shù)據都已收到,該恢復過程已經結束,可以回到恢復之前的狀態(tài)了,也即再次進入擁塞避免狀態(tài)。

快速重傳算法首次出現(xiàn)在4.3BSD的Tahoe版本,快速恢復首次出現(xiàn)在4.3BSD的Reno版本,也稱之為Reno版的TCP擁塞控制算法。

可以看出Reno的快速重傳算法是針對一個包的重傳情況的,然而在實際中,一個重傳超時可能導致許多的數(shù)據包的重傳,因此當多個數(shù)據包從一個數(shù)據窗口中丟失時并且觸發(fā)快速重傳和快速恢復算法時,問題就產生了。因此NewReno出現(xiàn)了,它在Reno快速恢復的基礎上稍加了修改,可以恢復一個窗口內多個包丟失的情況。具體來講就是:Reno在收到一個新的數(shù)據的ACK時就退出了快速恢復狀態(tài)了,而NewReno需要收到該窗口內所有數(shù)據包的確認后才會退出快速恢復狀態(tài),從而更一步提高吞吐量。

SACK就是改變TCP的確認機制,最初的TCP只確認當前已連續(xù)收到的數(shù)據,SACK則把亂序等信息會全部告訴對方,從而減少數(shù)據發(fā)送方重傳的盲目性。比如說序號1,2,3,5,7的數(shù)據收到了,那么普通的ACK只會確認序列號4,而SACK會把當前的5,7已經收到的信息在SACK選項里面告知對端,從而提高性能,當使用SACK的時候,NewReno算法可以不使用,因為SACK本身攜帶的信息就可以使得發(fā)送方有足夠的信息來知道需要重傳哪些包,而不需要重傳哪些包。
編輯:hfy

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • TCP
    TCP
    +關注

    關注

    8

    文章

    1416

    瀏覽量

    82793
  • 數(shù)據包
    +關注

    關注

    0

    文章

    269

    瀏覽量

    25356
  • SACK
    +關注

    關注

    0

    文章

    2

    瀏覽量

    7540
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    TCP BBR擁塞控制算法深度解析

    我一向覺得TCP擁塞控制算法太過復雜,而復雜的東西基本上就是用來裝逼的垃圾,直到遇到了bbr。
    發(fā)表于 11-06 09:26 ?3005次閱讀
    <b class='flag-5'>TCP</b> BBR<b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>深度解析

    TCP協(xié)議技術之擁塞控制算法

    擁塞控制是在網絡層和傳輸層進行的功能。在網絡層,擁塞控制可以通過路由
    的頭像 發(fā)表于 02-03 17:06 ?3758次閱讀
    <b class='flag-5'>TCP</b>協(xié)議技術之<b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>

    基于衛(wèi)星網絡TCP擁塞控制算法

    分析衛(wèi)星網絡的特點和現(xiàn)有慢啟動算法的不足,提出一種使擁塞窗口平滑增長的慢啟動算法。引入門限因子和粒度因子實現(xiàn)擁塞窗口指數(shù)增長和線性增長階段之
    發(fā)表于 03-20 13:54 ?18次下載

    MANET網絡TCP擁塞控制識別序列與恢復

    針對MANET 擁塞控制假象與真正的擁塞所需要的區(qū)分問題,提出非擁塞控制的3 種類型以及4 類引起包錯誤的類型。采用普適
    發(fā)表于 03-29 10:49 ?18次下載

    Linux中傳輸控制協(xié)議的擁塞控制分析

    TCP(transport control protocol)的性能在很大程度上取決于其所使用的擁塞控制算法。傳統(tǒng)的TCP在實現(xiàn)多種
    發(fā)表于 06-17 07:43 ?21次下載

    高速網絡TCP擁塞控制算法的研究

    針對TCP 在高速網絡中的缺陷,提出了改進的BIC TCP 擁塞控制算法。優(yōu)化
    發(fā)表于 09-17 10:18 ?15次下載

    基于EM算法擁塞鏈路檢測方法

    網絡擁塞會嚴重影響互聯(lián)網性能,甚至導致網絡崩潰。在發(fā)生擁塞時,準確檢測異常鏈路,定位擁塞位置、估計擁塞
    發(fā)表于 09-23 11:32 ?11次下載

    TCP擁塞控制算法的組合策略研究

    隨著互聯(lián)網規(guī)模的增長,擁塞已經成為一個重要的研究熱點。介紹了TCP 擁塞控制的四種基本算法。TCP
    發(fā)表于 12-25 15:14 ?20次下載

    基于模糊控制和壓縮感知的無線傳感網絡擁塞算法

    針對無線傳感網絡(WSN)的擁塞問題,提出了一種將模糊控制和壓縮感知(cs)技術相結合來緩解無線傳感網絡擁塞
    發(fā)表于 01-03 09:59 ?0次下載
    基于模糊<b class='flag-5'>控制</b>和壓縮感知的無線傳感<b class='flag-5'>網絡</b><b class='flag-5'>擁塞</b><b class='flag-5'>算法</b>

    具有預測與自我調節(jié)能力的擁塞控制算法

    隨著網絡技術的日益發(fā)展,計算機網絡擁塞問題已極大地影響了用戶的使用體驗與數(shù)據傳遞。單一地提高硬件設備的投入并不能持續(xù)地防止網絡
    發(fā)表于 01-18 16:18 ?0次下載
    具有預測與自我調節(jié)能力的<b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>

    如何用eBPF寫TCP擁塞控制算法?

    其實不想用這個題目的,只因為TCP相關的東西比較吸引人的眼球,這篇文章的主題還是eBPF,而不是TCP。 用eBPF寫TCP擁塞控制
    的頭像 發(fā)表于 12-26 09:44 ?2063次閱讀

    Linux內核網絡擁塞控制算法的具體實現(xiàn)框架(一)

    談起網絡擁塞控制,大家可能很熟悉八股文中的“加法增大“、”乘法減小“、”慢開始“、“擁塞避免”、“快重傳”、“快恢復”等概念。沒錯,這是一種經典網絡
    的頭像 發(fā)表于 07-28 11:32 ?1209次閱讀
    Linux內核<b class='flag-5'>網絡</b><b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>的具體實現(xiàn)框架(一)

    Linux內核網絡擁塞控制算法的實現(xiàn)框架(二)

    從上面的概念中可以得知,擁塞窗口可以間接反映網絡的狀況,進而去限制發(fā)送窗口的大小。擁塞窗口作為網絡擁塞
    的頭像 發(fā)表于 07-28 11:34 ?1319次閱讀
    Linux內核<b class='flag-5'>網絡</b><b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>的實現(xiàn)框架(二)

    Linux內核網絡擁塞控制算法的實現(xiàn)框架(三)

    下面看一個特別重要的框架,也可以稱為是擁塞控制引擎,如下結構體所示, tcp_congestion_ops描述了一套擁塞控制
    的頭像 發(fā)表于 07-28 11:38 ?1700次閱讀
    Linux內核<b class='flag-5'>網絡</b><b class='flag-5'>擁塞</b><b class='flag-5'>控制</b><b class='flag-5'>算法</b>的實現(xiàn)框架(三)

    TCP協(xié)議中的擁塞控制機制與網絡穩(wěn)定性

    TCP協(xié)議中的擁塞控制機制與網絡穩(wěn)定性的深度探討 隨著互聯(lián)網的快速發(fā)展,網絡流量呈現(xiàn)爆炸式增長,網絡
    的頭像 發(fā)表于 04-19 16:42 ?915次閱讀