国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

如何解決TCP窗口與擁塞? TCP窗口與擁塞控制的解決辦法

這篇具有很好參考價(jià)值的文章主要介紹了如何解決TCP窗口與擁塞? TCP窗口與擁塞控制的解決辦法。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

  計(jì)算機(jī)網(wǎng)絡(luò)中的帶寬、交換結(jié)點(diǎn)中的緩存和處理機(jī)等,都是網(wǎng)絡(luò)的資源。在某段時(shí)間,若對(duì)網(wǎng)絡(luò)中某一資源的需求超過(guò)了該資源所能提供的可用部分,網(wǎng)絡(luò)的性能就會(huì)變壞。這種情況就叫做擁塞。擁塞控制就是防止過(guò)多的數(shù)據(jù)注入網(wǎng)絡(luò)中,這樣可以使網(wǎng)絡(luò)中的路由器或鏈路不致過(guò)載。擁塞控制是一個(gè)全局性的過(guò)程,和流量控制不同,流量控制指點(diǎn)對(duì)點(diǎn)通信量的控制。

  TCP通過(guò)滑動(dòng)窗口機(jī)制檢測(cè)丟包,并在丟包發(fā)生時(shí)調(diào)整數(shù)據(jù)傳輸速率?;瑒?dòng)窗口機(jī)制利用數(shù)據(jù)接收端的接收窗口來(lái)控制數(shù)據(jù)流。

  接收窗口值由數(shù)據(jù)接收端指定,以字節(jié)數(shù)形式存儲(chǔ)于TCP報(bào)文頭,并告知傳輸設(shè)備有多少數(shù)據(jù)將會(huì)存儲(chǔ)在TCP緩沖區(qū)。緩沖區(qū)就是數(shù)據(jù)暫時(shí)放置的地方,直至傳遞至應(yīng)用層協(xié)議等待處理。因此,發(fā)送端每次只能發(fā)送Window Size字段指定的數(shù)據(jù)量。為了使發(fā)送端繼續(xù)傳送數(shù)據(jù),接收端必須發(fā)送確認(rèn)信息:之前的數(shù)據(jù)接收到了。同時(shí)必須對(duì)占用緩沖區(qū)的數(shù)據(jù)進(jìn)行處理以釋放緩存空間。下圖顯示了接收窗口是如何工作的:

  上圖中,客戶端向服務(wù)器發(fā)送數(shù)據(jù),服務(wù)器接收窗口是5000字節(jié)??蛻舳税l(fā)送了2500字節(jié),服務(wù)器緩沖區(qū)還剩2500字節(jié),之后又發(fā)送了2000字節(jié),從而緩沖區(qū)只剩500字節(jié)。服務(wù)器發(fā)送確認(rèn)信息。對(duì)緩存中數(shù)據(jù)進(jìn)行處理并清空緩存。此過(guò)程重復(fù)進(jìn)行,客戶端又發(fā)送3000字節(jié)和1000字節(jié),服務(wù)器緩存減少至1000字節(jié),客戶端再次確認(rèn)數(shù)據(jù)并處理緩存中內(nèi)容。

  調(diào)整窗口大?。?/strong>

  當(dāng)TCP堆 棧接收到數(shù)據(jù)的時(shí)候,生成一個(gè)確認(rèn)信息并以回復(fù)的方式發(fā)送,但是放置在接收端緩存中的數(shù)據(jù)并不總是立即被處理。當(dāng)服務(wù)器忙于處理從多個(gè)客戶端接收的報(bào)文, 服務(wù)器很有可能因?yàn)榍謇砭彺娑兊镁徛?,無(wú)法騰出空間接收新的數(shù)據(jù),如果沒(méi)有流控,則可能會(huì)造成丟包和數(shù)據(jù)損壞。好在,接收窗口所設(shè)定的速率無(wú)法使服務(wù)器 正常處理數(shù)據(jù)時(shí),能夠調(diào)整接收窗口大小。通過(guò)減小返回給發(fā)送端的ACK報(bào)文的TCP頭窗口大小值來(lái)實(shí)現(xiàn)。如下圖所示:

  上圖中,服務(wù)器初始窗口大小為5000字節(jié)??蛻舳税l(fā)送2000字節(jié),之后又發(fā)送了2000字節(jié),緩沖區(qū)中只有1000字節(jié)可用。服務(wù)器意識(shí)到緩沖區(qū)正在快速填滿,它知道如果數(shù)據(jù)繼續(xù)以此速率傳輸,很快會(huì)有報(bào)文丟失。為了防止報(bào)文丟失,服務(wù)器發(fā)送確認(rèn)信息給客戶端,更新窗口大小為1000字節(jié)。結(jié)果,客戶端減少數(shù)據(jù)發(fā)送,服務(wù)器以可以接受的速率處理緩存內(nèi)容,即保持?jǐn)?shù)據(jù)流以穩(wěn)定的速率傳輸。

  調(diào)整窗口大小在兩個(gè)方向都是可行的。當(dāng)服務(wù)器能夠更加快速的處理報(bào)文時(shí),它會(huì)發(fā)送一個(gè)較大窗口的ACK報(bào)文。

  零窗口暫停數(shù)據(jù)流:

  某些情況下,服務(wù)器無(wú)法再處理從客戶端發(fā)送的數(shù)據(jù)??赡苁怯捎趦?nèi)存不足,處理能力不夠,或其他原因。這可能會(huì)造成數(shù)據(jù)被丟棄以及傳輸暫停,但接收窗口能夠幫助減小負(fù)面影響。

  當(dāng)上述情況發(fā)生時(shí),服務(wù)器會(huì)發(fā)送窗口為0的報(bào)文。當(dāng)客戶端接收到此報(bào)文時(shí),它會(huì)暫停所有數(shù)據(jù)傳輸,但會(huì)保持與服務(wù)器的連接以傳輸探測(cè)(keep-alive)報(bào)文。探測(cè)報(bào)文在客戶端以穩(wěn)定間隙發(fā)送,以查看服務(wù)器接收窗口狀態(tài)。一旦服務(wù)器能夠再次處理數(shù)據(jù),將會(huì)返回非零值窗口大小,傳輸會(huì)恢復(fù)。下圖示例了零窗口通知過(guò)程。

  服務(wù)器初始接收數(shù)據(jù)窗口為5000字節(jié)大小。從客戶端接收4000字節(jié)數(shù)據(jù)之后,服務(wù)器負(fù)載變得非常繁重,無(wú)法繼續(xù)處理客戶端任何數(shù)據(jù)。服務(wù)器于是發(fā)送窗口大小值為0的報(bào)文??蛻舳藭和?shù)據(jù)傳輸并發(fā)送一個(gè)探測(cè)報(bào)文。探測(cè)報(bào)文之后,服務(wù)器回復(fù)以告知客戶端現(xiàn)在可以接收數(shù)據(jù)的報(bào)文,以及窗口大小為1000字節(jié)??蛻舳嘶謴?fù)傳送數(shù)據(jù)。

  TCP滑動(dòng)窗口實(shí)戰(zhàn):

  本例中,開(kāi)始從192.168.0.20發(fā)送至192.168.0.30。我們關(guān)心的是窗口大小字段,可以從Packet List面板的Info欄以及Packet Details的TCP報(bào)文頭看到。前三個(gè)報(bào)文后,可看到該值立刻減小,如下圖所示:

  窗口大小值從第一個(gè)報(bào)文的8760字節(jié)變成第二個(gè)報(bào)文的5840字節(jié)到第三個(gè)報(bào)文的2920字節(jié)①。窗口大小值的減小是主機(jī)延時(shí)的典型標(biāo)志。在時(shí)間欄注意到這一過(guò)程發(fā)生的非常迅速②。當(dāng)窗口大小迅速減小的時(shí)候,通常就有可能下降為零。這就是第四個(gè)報(bào)文所發(fā)生的,如下圖所示:

  第四個(gè)報(bào)文從192.168.0.20發(fā)送至192.168.0.30,目的是告訴192.168.0.30它不再接收任何數(shù)據(jù)。0值見(jiàn)于TCP報(bào)文頭①,Wireshark的Packet List面板Info欄,以及TCP報(bào)文頭的SEQ/ACK Analysis字段②也告訴我們這是一個(gè)0窗口報(bào)文。

  一旦發(fā)送了零窗口報(bào)文,192.168.0.30的設(shè)備不會(huì)再發(fā)送任何數(shù)據(jù),直到收到從192.168.0.20的窗口更新,告知窗口大小已經(jīng)增加了。本例中導(dǎo)致零窗口的問(wèn)題是暫時(shí)的,所以在下一個(gè)報(bào)文中發(fā)送了窗口更新信息,如下圖所示。

  本例中,窗口大小增加到一個(gè)非常健康的數(shù)值64,240字節(jié)①。Wireshark再次在SEQ/ACK Analysis告訴我們這是一個(gè)窗口更新。

  一旦收到更新報(bào)文,192.168.0.30的主機(jī)就再次開(kāi)始發(fā)送數(shù)據(jù),在報(bào)文6和報(bào)文7中。這一過(guò)程發(fā)生很快。如果它持續(xù)時(shí)間再長(zhǎng)一點(diǎn),就可能會(huì)導(dǎo)致網(wǎng)絡(luò)的潛在中斷,引起數(shù)據(jù)傳輸減慢或失敗。

  下一個(gè)關(guān)于滑動(dòng)窗口的例子,第一個(gè)報(bào)文是正常HTTP,從195.81.202.68至172.31.136.85。此報(bào)文之后立刻跟隨一個(gè)從172.31.136.85發(fā)送的零窗口報(bào)文,如下圖所示:

  這與上一個(gè)例子中的零窗口報(bào)文十分類似,但結(jié)果顯著不同,172.31.136.85主機(jī)不是發(fā)送一個(gè)窗口更新并回復(fù)通訊,而是一個(gè)探測(cè)報(bào)文,如下圖所示:

  此報(bào)文被Wireshark標(biāo)注為探測(cè)報(bào)文①。時(shí)間欄告訴我們這一報(bào)文發(fā)生于最后一個(gè)接收到的報(bào)文3.4秒之后。這一過(guò)程持續(xù)若干次,一端發(fā)送零窗口報(bào)文另一端發(fā)送探測(cè)報(bào)文,如下圖所示:

  探測(cè)報(bào)文發(fā)送間隙為3.4,6.8,13.5秒。這一過(guò)程可能會(huì)持續(xù)相當(dāng)長(zhǎng)一段時(shí)間,取決于通訊設(shè)備的操作系統(tǒng)。該情況下,把時(shí)間欄的值加起來(lái),通訊暫停了25秒。

  TCP差錯(cuò)控制和流控排查總結(jié):

  重傳報(bào)文

  重 傳的發(fā)生是由于客戶端檢測(cè)到服務(wù)器沒(méi)有接收到它所發(fā)送的數(shù)據(jù)。因此,取決于你所分析的是通訊的哪一端,有可能是看不見(jiàn)重傳的。如果從服務(wù)器端抓取數(shù)據(jù),并 且它確實(shí)沒(méi)有接收到客戶端所發(fā)送的和重傳報(bào)文,可能會(huì)一無(wú)所獲因?yàn)闊o(wú)法看見(jiàn)重傳報(bào)文。如果懷疑并不是服務(wù)器端導(dǎo)致的報(bào)文丟失,可以考慮在客戶端嘗試抓取報(bào) 文,以查看實(shí)際是否有重傳發(fā)生。

  重復(fù)ACK

  可以將重復(fù)ACK看作重傳的“所謂相反面”,因?yàn)樗窃诜?wù)器檢測(cè)到客戶端發(fā)送報(bào)文丟失的時(shí)候產(chǎn)生的。大多數(shù)情況下,在通訊兩端抓取流量時(shí)都可以看到重復(fù)ACK。需記住當(dāng)接收?qǐng)?bào)文亂序時(shí)會(huì)觸發(fā)重復(fù)ACK。例如,如果服務(wù)器之接收到發(fā)送的第一個(gè)和第三個(gè)報(bào)文,就會(huì)導(dǎo)致發(fā)送重復(fù)ACK引起客戶端對(duì)第二個(gè)報(bào)文的快速重傳,因?yàn)槟阋呀?jīng)收到了第一個(gè)和第三個(gè)報(bào)文,因此不管導(dǎo)致第二個(gè)報(bào)文丟棄的原因是什么,都很有可能是暫時(shí)的,因此大多數(shù)情況下重復(fù)ACK都會(huì)成功發(fā)送和接收。當(dāng)然,這種情形并不一定永遠(yuǎn)會(huì)發(fā)生,因此當(dāng)你懷疑在服務(wù)器端丟失報(bào)文而又看不到任何重復(fù)ACK,考慮從通訊的客戶端抓取報(bào)文。

  零窗口和探測(cè)報(bào)文

  滑動(dòng)窗口直接與服務(wù)器無(wú)法接收和處理報(bào)文有關(guān),任何窗口大小的縮小以及零值都是服務(wù)器問(wèn)題的直接結(jié)果。所以如果你在哪里看到這兩者之一發(fā)生,就應(yīng)該在那里深入研究。通常應(yīng)當(dāng)在網(wǎng)絡(luò)通訊兩端一直主機(jī)窗口更新報(bào)文。

  以上就是解決TCP窗口與擁塞控制的辦法,希望能幫到大家,謝謝閱讀。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-466365.html

到了這里,關(guān)于如何解決TCP窗口與擁塞? TCP窗口與擁塞控制的解決辦法的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • TCP的滑動(dòng)窗口與擁塞控制

    TCP的滑動(dòng)窗口與擁塞控制

    客戶端每發(fā)送的一個(gè)包,服務(wù)器端都應(yīng)該有個(gè)回復(fù),如果服務(wù)器端超過(guò)一定的時(shí)間沒(méi)有回復(fù),客戶端就會(huì)重新發(fā)送這個(gè)包,直到有回復(fù)。 為了保證順序性,每一個(gè)包都有一個(gè) ID。在建立連接的時(shí)候,會(huì)商定起始的 ID 是什么,然后按照 ID 一個(gè)個(gè)發(fā)送。為了保證不丟包,對(duì)于發(fā)

    2024年02月07日
    瀏覽(23)
  • TCP的滑動(dòng)窗口和擁塞控制

    TCP的滑動(dòng)窗口和擁塞控制

    目錄 滑動(dòng)窗口 1.發(fā)送窗口和接收窗口 2.滑動(dòng)窗口的分類 停止等待協(xié)議:發(fā)送窗口大小 = 1, 接收窗口大小= 1 后退N幀協(xié)議(GBN):發(fā)送窗口大小 1,接收窗口大小 = 1 選擇重傳協(xié)議(SR) :發(fā)送窗口大小 1, 接收窗口大小 1 擁塞控制 慢開(kāi)始算法和擁塞避免: 快重傳和快恢復(fù):

    2024年04月10日
    瀏覽(26)
  • TCP滑動(dòng)窗口、流量控制及擁塞控制詳解

    TCP滑動(dòng)窗口、流量控制及擁塞控制詳解

    TCP雖然是面向字節(jié)流的,但是TCP傳輸?shù)膯卧_實(shí)報(bào)文段。一個(gè)TCP報(bào)文段分為首部和數(shù)據(jù)部分。TCP首部前20個(gè)字節(jié)是固定的,后面有4N個(gè)字節(jié)是可選的。因此,TCP首部最小字節(jié)數(shù)是20個(gè)字節(jié)。 下面我們看下一TCP首部中幾個(gè)重要的字段: 源端口 和 目的端口 各占兩個(gè)字節(jié) 序號(hào) ,占

    2024年02月02日
    瀏覽(28)
  • TCP重傳機(jī)制、滑動(dòng)窗口、擁塞控制

    TCP重傳機(jī)制、滑動(dòng)窗口、擁塞控制

    一、總述 TCP,Transmission Control Protocol,是一個(gè)面向連接、基于 流式傳輸 的 可靠傳輸 協(xié)議,考慮到的內(nèi)容很多,比如數(shù)據(jù)包的丟失、損壞、分片和亂序等,TCP協(xié)議通過(guò)多種不同的機(jī)制來(lái)實(shí)現(xiàn)可靠傳輸。今天,重點(diǎn)分析 重傳機(jī)制 、 滑動(dòng)窗口 ,以及 擁塞控制 。 二、重傳機(jī)制

    2024年04月10日
    瀏覽(29)
  • 擁塞控制(TCP限制窗口大小的機(jī)制)

    擁塞控制(TCP限制窗口大小的機(jī)制)

    ? ? ? ??擁塞控制機(jī)制可以使滑動(dòng)窗口在保證可靠性的前提下,提高傳輸效率 ? ? ? ? 關(guān)于滑動(dòng)窗口的屬性以及部分機(jī)制推薦看TCP中窗口和滑動(dòng)窗口的含義以及流量控制 ? ? ? ? 看了上面推薦的博客我們已經(jīng)知道了,由于接收方接收數(shù)據(jù)的能力有限,所以要通過(guò)流量控制的

    2024年02月11日
    瀏覽(25)
  • 網(wǎng)絡(luò)編程(12): TCP重傳、滑動(dòng)窗口、流量控制、擁塞控制

    通過(guò)序列號(hào)和確認(rèn)號(hào)確保可靠傳輸,當(dāng)發(fā)送端發(fā)送數(shù)據(jù)給接收到,接收端會(huì)返回一個(gè)確認(rèn)號(hào),表示收到消息了 超時(shí)重傳 :沒(méi)有在指定時(shí)間內(nèi)收到 ACK 報(bào)文 超時(shí)重傳的兩種可能: 數(shù)據(jù)包丟失 、 確認(rèn)包丟失 超時(shí)重傳時(shí)間 RTO : RTO 較大:重發(fā)就變慢了,丟包之后需要半天才能重

    2024年02月12日
    瀏覽(28)
  • 【網(wǎng)絡(luò)】傳輸層——TCP(滑動(dòng)窗口&&流量控制&&擁塞控制&&延遲應(yīng)答&&捎帶應(yīng)答)

    【網(wǎng)絡(luò)】傳輸層——TCP(滑動(dòng)窗口&&流量控制&&擁塞控制&&延遲應(yīng)答&&捎帶應(yīng)答)

    ??作者:一只大喵咪1201 ??專欄:《網(wǎng)絡(luò)》 ??格言: 你只管努力,剩下的交給時(shí)間! 上篇文章對(duì)TCP可靠性機(jī)制講解了一部分,這篇文章接著繼續(xù)講解。 在上篇文章中,本喵講解了TCP的確認(rèn)應(yīng)答機(jī)制: 如上圖所示,主機(jī)A每發(fā)送一個(gè)數(shù)據(jù)段,主機(jī)B都要給一個(gè) ACK 確認(rèn)應(yīng)答,

    2024年02月12日
    瀏覽(21)
  • 網(wǎng)路原理-傳輸層UDP,TCP/IP(確認(rèn)應(yīng)答,超時(shí)重傳,連接管理,三次握手,四次揮手,狀態(tài)轉(zhuǎn)換,流量控制,滑動(dòng)窗口,擁塞控制,延時(shí)應(yīng)答,捎帶應(yīng)答,異常情況,面向字節(jié)流)-網(wǎng)絡(luò)層(IP協(xié)議,地址管理)

    網(wǎng)路原理-傳輸層UDP,TCP/IP(確認(rèn)應(yīng)答,超時(shí)重傳,連接管理,三次握手,四次揮手,狀態(tài)轉(zhuǎn)換,流量控制,滑動(dòng)窗口,擁塞控制,延時(shí)應(yīng)答,捎帶應(yīng)答,異常情況,面向字節(jié)流)-網(wǎng)絡(luò)層(IP協(xié)議,地址管理)

    本節(jié)重點(diǎn) ? 理解傳輸層的作?,深?理解TCP的各項(xiàng)特性和機(jī)制 ? 對(duì)整個(gè)TCP/IP協(xié)議有系統(tǒng)的理解 ? 對(duì)TCP/IP協(xié)議體系下的其他重要協(xié)議和技術(shù)有?定的了解 我們之前編寫(xiě)完了基本的 java socket ,要知道,我們之前所寫(xiě)的所有代碼都在應(yīng)?層,都是為了 完成某項(xiàng)業(yè)務(wù),如翻譯等。

    2024年04月15日
    瀏覽(27)
  • 八股文——TCP四大機(jī)制!小白也能懂?。ㄖ貍鳈C(jī)制、滑動(dòng)窗口、流量控制、擁塞控制)

    八股文——TCP四大機(jī)制!小白也能懂?。ㄖ貍鳈C(jī)制、滑動(dòng)窗口、流量控制、擁塞控制)

    TCP巨復(fù)雜!同時(shí)在八股計(jì)算機(jī)網(wǎng)絡(luò)中也經(jīng)常被問(wèn)到,必須會(huì)!這篇文章將讓小白有個(gè)大體框架,知道怎么個(gè)事,面試中可以有話說(shuō),也能讓佬更加鞏固知識(shí)點(diǎn)。 TCP是一個(gè)可靠的傳輸協(xié)議,為了保證它的可靠性,出現(xiàn)七七八八的機(jī)制,它可能有數(shù)據(jù)的破壞、丟包、重復(fù)以及分片

    2024年04月25日
    瀏覽(25)
  • 論TCP協(xié)議中的擁塞控制機(jī)制與網(wǎng)絡(luò)穩(wěn)定性

    TCP協(xié)議中的擁塞控制機(jī)制與網(wǎng)絡(luò)穩(wěn)定性的深度探討 隨著互聯(lián)網(wǎng)的快速發(fā)展,網(wǎng)絡(luò)流量呈現(xiàn)爆炸式增長(zhǎng),網(wǎng)絡(luò)擁塞問(wèn)題逐漸凸顯。為了維護(hù)網(wǎng)絡(luò)的穩(wěn)定運(yùn)行,TCP協(xié)議中引入了擁塞控制機(jī)制。這一機(jī)制的主要目的是防止過(guò)多的數(shù)據(jù)注入網(wǎng)絡(luò),從而避免網(wǎng)絡(luò)擁塞。然而,盡管擁塞控

    2024年04月22日
    瀏覽(23)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包