成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

TCP窗口與擁塞處理

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

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é)。客戶端發(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)整窗口大小:

當(dāng)TCP堆 棧接收到數(shù)據(jù)的時(shí)候,生成一個(gè)確認(rèn)信息并以回復(fù)的方式發(fā)送,但是放置在接收端緩存中的數(shù)據(jù)并不總是立即被處理。當(dāng)服務(wù)器忙于處理從多個(gè)客戶端接收的報(bào)文, 服務(wù)器很有可能因?yàn)榍謇砭彺娑兊镁徛瑹o(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é)。客戶端發(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)文。

責(zé)任編輯:林琳 來(lái)源: EMC中文支持論壇
相關(guān)推薦

2019-04-16 11:02:10

TCPIPLinux

2023-12-26 01:07:03

TCP擁塞控制

2020-02-10 20:54:48

擁塞流量控制

2020-07-23 15:01:15

TCP流量擁塞

2009-01-18 09:28:00

TCPIP路由器

2011-08-23 14:10:07

TCPECN路由器

2021-10-11 14:27:06

TCP擁塞控制

2019-11-26 08:24:13

TCP擁塞控制網(wǎng)絡(luò)協(xié)議

2020-04-20 10:51:26

TCP擁塞控制網(wǎng)絡(luò)協(xié)議

2010-06-10 15:14:32

TCP傳輸控制協(xié)議

2023-11-10 16:28:02

TCP窗口

2023-08-11 07:44:40

TCP滑動(dòng)窗口數(shù)據(jù)

2022-02-15 08:30:04

TCP三次握手四次揮手

2022-10-17 08:21:29

UDPTCP

2023-10-17 16:30:00

TCP

2020-10-12 19:50:30

TCP窗口時(shí)間戳SACK

2010-09-27 13:35:43

TCP IP故障

2024-10-15 09:48:56

2009-07-27 14:03:54

網(wǎng)絡(luò)擁塞網(wǎng)速變慢

2022-06-27 08:59:21

數(shù)據(jù)包TCP/IP協(xié)議棧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 正在播放国产精品 | 国产伦精品一区二区三区精品视频 | 色婷婷激情| 国产激情视频网 | 天堂在线网 | 91视频免费观看 | 亚洲免费视频在线观看 | 欧美毛片免费观看 | 日本特黄a级高清免费大片 成年人黄色小视频 | 日日夜夜精品视频 | 日韩在线视频免费观看 | 亚洲国产福利视频 | 天堂素人约啪 | 久日精品 | 国产在线一区二区 | 国产一区中文 | 国产精品一区二区久久久久 | 日韩欧美在线不卡 | 国产色网 | 一本色道精品久久一区二区三区 | 午夜视频在线观看视频 | 在线a视频网站 | 国产精品成av人在线视午夜片 | 夜夜草| 午夜大片 | 中文字幕一区二区三区乱码在线 | av中文字幕在线观看 | 欧美黑人一区 | 精品一区二区三区在线播放 | 欧美综合国产精品久久丁香 | 美女视频. | 羞羞视频免费观看入口 | 麻豆av片 | 精精国产xxxx视频在线野外 | japanhd美女动 | 日韩成人影院 | 成人国产精品久久久 | 亚洲一一在线 | 二区三区av | www.国产精| 日韩欧美国产精品一区二区三区 |