Protokol posuvného okna - Sliding window protocol

A protokol posuvného okna je funkce založená na paketech přenos dat protokoly. Protokoly posuvného okna se používají tam, kde je vyžadováno spolehlivé doručování paketů v pořadí, například v vrstva datového spojení (OSI vrstva 2 ) a také v protokol kontroly přenosu (TCP). Používají se také ke zlepšení účinnosti, když kanál může obsahovat vysokou hodnotu latence.

Systémy založené na paketech jsou založeny na myšlence zasílání dávky dat balíček, spolu s dalšími daty, která přijímači umožňují zajistit, aby byl přijat správně, možná a kontrolní součet. Když příjemce ověří data, odešle potvrzovací signál, nebo „ACK“, zpět odesílateli, což znamená, že může odeslat další paket. Jednoduše automatické opakování požadavku protokolu (ARQ), odesílatel se zastaví po každém paketu a čeká na přijetí ACK. Tím je zajištěno, že pakety dorazí ve správném pořadí, protože najednou lze odeslat pouze jeden.

Čas potřebný k přijetí signálu ACK může představovat značné množství času ve srovnání s časem potřebným k odeslání paketu. V tomto případě celkově propustnost může být mnohem nižší, než je teoreticky možné. Za tímto účelem protokoly posuvného okna umožňují vybraný počet paketů, okno, které budou odeslány, aniž byste museli čekat na ACK. Každý paket obdrží pořadové číslo a ACK toto číslo pošlou zpět. Protokol sleduje, které pakety byly ACKed, a když jsou přijaty, odešle více paketů. Tímto způsobem okno diapozitivy podél proudu paketů tvořících přenos.

Posuvná okna jsou klíčovou součástí mnoha protokolů. Jedná se o klíčovou součást protokolu TCP, který ze své podstaty umožňuje, aby pakety dorazily mimo pořadí, a nachází se také v mnoha protokoly pro přenos souborů jako UUCP-g a ZMODEM jako způsob zlepšení efektivity ve srovnání s neokázanými protokoly jako XMODEM.

Základní koncept

Koncepčně je každé části přenosu (pakety ve většině vrstev datových spojů, ale bajty v TCP) přiřazeno jedinečné po sobě jdoucí pořadové číslo a přijímač používá čísla k umístění přijatých paketů ve správném pořadí, vyřazení duplicitních paketů a identifikaci chybějících . Problém je v tom, že neexistuje žádné omezení velikosti pořadového čísla, které lze požadovat.

Stanovením omezení počtu paketů, které lze kdykoli odeslat nebo přijmout, protokol posuvného okna umožňuje komunikovat neomezený počet paketů pomocí sekvenčních čísel pevné velikosti. Termín „okno“ na straně vysílače představuje logická hranice celkového počtu paketů, které ještě příjemce musí potvrdit. Přijímač informuje vysílač v každém potvrzovacím paketu o aktuální maximální velikosti vyrovnávací paměti přijímače (hranice okna). Záhlaví TCP používá 16bitové pole k hlášení velikosti okna přijímače odesílateli. Proto je největší okno, které lze použít, 216 = 64 kilobajtů.

V režimu pomalého startu vysílač začíná s nízkým počtem paketů a zvyšuje počet paketů v každém přenosu po přijetí potvrzovacích paketů z přijímače. Pro každého ack paket přijato, okno se posune o jeden paket (logicky) a přenese jeden nový paket. Když je dosaženo prahové hodnoty okna, vysílač vysílá jeden paket pro jeden přijatý potvrzovací paket.

Pokud je limit okna 10 paketů, pak v režimu pomalého startu může vysílač začít vysílat jeden paket následovaný dvěma pakety (před přenosem dvou paketů musí být přijat jeden paket ack), následovaný třemi pakety atd. Až do 10 paketů. Ale po dosažení 10 paketů jsou další přenosy omezeny na jeden paket vyslaný pro jeden přijatý potvrzovací paket. V simulaci to vypadá, jako by se okno pohybovalo o jednu vzdálenost paketu pro každý přijatý paket. Na straně přijímače také okno přesune jeden paket za každý přijatý paket.

Metoda posuvného okna zajišťuje tento provoz dopravní zácpy v síti je zabráněno. Aplikační vrstva bude i nadále nabízet data pro přenos do TCP, aniž by se obávala problémů s přetížením síťového provozu, protože TCP na straně odesílatele a příjemce implementuje posuvná okna vyrovnávací paměti paketů. Velikost okna se může dynamicky lišit v závislosti na síťovém provozu.

Pro nejvyšší možné propustnost, je důležité, aby vysílač nebyl nucen zastavit odesílání protokolem posuvného okna dříve než jeden zpáteční zpoždění (RTT). Omezení množství dat, které může odeslat před zastavením a čekáním na potvrzení by měl být větší než produkt se zpožděním šířky pásma komunikačního spojení. Pokud tomu tak není, protokol omezí účinnost šířka pásma odkazu.

Motivace

V jakémkoli komunikačním protokolu založeném na automatické opakování požadavku pro kontrola chyb, přijímač musí potvrdit přijaté pakety. Pokud vysílač neobdrží potvrzení v přiměřené době, odešle data znovu.

Vysílač, který neobdrží potvrzení, nemůže vědět, zda přijímač skutečně přijal paket; může se stát, že došlo ke ztrátě nebo poškození přenosu. Pokud detekce chyb mechanismus odhaluje poškození, paket bude přijímačem ignorován a přijímač pošle negativní nebo duplicitní potvrzení. Přijímač může být také nakonfigurován tak, aby vůbec neposílal žádné potvrzení. Obdobně si příjemce není jistý, zda přijímá jeho potvrzení. Může se stát, že bylo odesláno potvrzení, ale bylo ztraceno nebo poškozeno na přenosovém médiu. V takovém případě musí přijímač potvrdit opakovaný přenos, aby se zabránilo nepřetržitému odesílání dat, ale musí jej jinak ignorovat.

Provoz protokolu

Vysílač i přijímač mají aktuální pořadové číslo nt a nr, resp. Každý z nich má také velikost okna wt a wr. Velikosti oken se mohou lišit, ale v jednodušších implementacích jsou opraveny. U každého pokroku musí být velikost okna větší než nula.

Jak je obvykle implementováno, nt je další paket, který má být vysílán, tj. pořadové číslo prvního paketu, který ještě nebyl přenesen. Rovněž, nr je první paket, který ještě nebyl přijat. Obě čísla jsou monotónně roste s časem; jen se někdy zvyšují.

Přijímač může také sledovat nejvyšší dosud obdržené pořadové číslo; proměnná ns je o jedno více než pořadové číslo nejvyššího přijatého pořadového čísla. Pro jednoduché přijímače, které přijímají pouze pakety v pořadí (wr = 1), to je stejné jako nr, ale může být větší, pokud wr > 1. Všimněte si rozdílu: všechny pakety níže nr byly přijaty, žádné balíčky výše ns byly přijaty a mezi nr a ns, bylo přijato několik paketů.

Když přijímač přijme paket, odpovídajícím způsobem aktualizuje své proměnné a odešle potvrzení s novým nr. Vysílač sleduje nejvyšší potvrzení, které obdržel nA. Vysílač ví, že všechny pakety až, ale ne včetně nA byly přijaty, ale není si jistý o paketech mezi nimi nA a ns; tj. nAnrns.

Pořadová čísla se vždy řídí pravidlem, že nAnrnsntnA + wt. To je:

  • nAnr: Nejvyšší potvrzení přijaté vysílačem nemůže být vyšší než nejvyšší nr potvrzeno přijímačem.
  • nrns: Rozsah plně přijatých paketů nemůže přesahovat konec částečně přijatých paketů.
  • nsnt: Nejvyšší přijatý paket nemůže být vyšší než nejvyšší odeslaný paket.
  • ntnA + wt: Nejvyšší odeslaný paket je omezen nejvyšším přijatým potvrzením a velikostí vysílacího okna.

Provoz vysílače

Kdykoli má vysílač data k odeslání, může vysílat až wt pakety před nejnovějším potvrzením nA. To znamená, že může přenášet číslo paketu nt tak dlouho jak nt < nA+wt.

Pokud nedojde k chybě komunikace, vysílač brzy obdrží potvrzení o všech odeslaných paketech a odejde nA rovná nt. Pokud k tomu nedojde po přiměřeném zpoždění, musí vysílač mezi nimi znovu vyslat pakety nA a nt.

Techniky pro definování „přiměřeného zpoždění“ mohou být velmi komplikované, ale ovlivňují pouze účinnost; základní spolehlivost protokolu posuvného okna nezávisí na detailech.

Provoz přijímače

Pokaždé, když byl paket očíslován X je přijímán, přijímač zkontroluje, zda spadne do přijímacího okna, nrX < nr+wr. (Nejjednodušší přijímače musí sledovat pouze jednu hodnotu nr=ns.) Pokud spadne do okna, přijímač to přijme. Pokud je očíslovaný nr, je přijímací pořadové číslo zvýšeno o 1 a možná i více, pokud byly dříve přijaty a uloženy další po sobě jdoucí pakety. Li X > nr, paket je uložen, dokud nebudou přijaty všechny předchozí pakety.[1] Li Xns, druhý je aktualizován na ns=X+1.

Pokud číslo paketu není v přijímacím okně, přijímač ho zahodí a nezmění ho nr nebo ns.

Bez ohledu na to, zda byl paket přijat, či nikoli, přijímač vysílá potvrzení obsahující aktuální nr. (Potvrzení může také obsahovat informace o dalších paketech přijatých mezi nr nebo ns, ale to jen pomáhá efektivitě.)

Všimněte si, že nemá smysl mít přijímací okno wr větší než vysílací okno wt, protože není třeba se obávat přijetí paketu, který nebude nikdy přenesen; užitečný rozsah je 1 ≤ wrwt.

Je vyžadován rozsah pořadových čísel

Pořadová čísla modulo 4, s wr= 1. Zpočátku, nt=nr=0

Protokol byl dosud popsán, jako by pořadová čísla měla neomezenou velikost a neustále se zvyšovala. Spíše než vysílat celé pořadové číslo X ve zprávách je možné přenášet pouze X modN, pro některé konečné N. (N je obvykle a síla 2.)

Například vysílač obdrží pouze potvrzení v rozsahu nA na nt, včetně. Protože to zaručuje ntnA ≤ wt, existuje nanejvýš wt+1 možné pořadové číslo, které by mohlo dorazit kdykoli. Vysílač tedy může jednoznačně dekódovat pořadové číslo, pokud N > wt.

Přijímač ukládá silnější omezení. Fungování protokolu závisí na tom, zda přijímač dokáže spolehlivě rozlišit nové pakety (které by měly být přijaty a zpracovány) od opakovaných přenosů starých paketů (které by měly být vyřazeny a poslední potvrzení znovu vysíláno). Toho lze dosáhnout na základě znalosti velikosti okna vysílače. Po obdržení očíslovaného paketu X, přijímač to ví X < nA+wt, tak nA > Xwt. Pakety byly očíslovány Xwt již nebude znovu vysílán.

Nejnižší pořadové číslo, které kdy v budoucnu obdržíme, je nswt

Přijímač také ví, že vysílač je nA nemůže být vyšší než nejvyšší zaslané potvrzení, jaké kdy bylo nr. Takže nejvyšší pořadové číslo, jaké jsme mohli vidět, je nr+wt ≤ ns+wt.

Existují tedy 2wt různá pořadová čísla, která přijímač může přijímat najednou. Mohlo by se tedy zdát, že musíme mít N ≥ 2wt. Skutečný limit je však nižší.

Dalším poznatkem je, že přijímač nemusí rozlišovat mezi příliš nízkými pořadovými čísly (méně než nr) nebo které jsou příliš vysoké (větší nebo rovno ns+wr). V obou případech přijímač ignoruje paket s výjimkou opakovaného přenosu potvrzení. Je tedy nutné pouze to N ≥ wt+wr. Jak je běžné mít wr<wt (např. viz Go-Back-N níže), toto může dovolit větší wt v pevném stavu N.

Příklady

Nejjednodušší posuvné okno: stop-and-wait

Ačkoli se běžně odlišuje od protokolu posuvného okna, zastavit a počkat ARQ protokol je vlastně nejjednodušší možná implementace. Vysílací okno je 1 paket a přijímací okno je 1 paket. Tím pádem, N = 2 možná pořadová čísla (pohodlně reprezentovaná jediným bit ) jsou potřeba.

Příklad nejednoznačnosti

Vysílač střídavě odesílá pakety označené „liché“ a „sudé“. Potvrzení rovněž říkají „liché“ a „sudé“. Předpokládejme, že vysílač poté, co poslal lichý paket, nečekal na liché potvrzení a místo toho okamžitě poslal následující sudý paket. Mohlo by to poté obdržet potvrzení, že „čeká další lichý paket“. Tím by se vysílač dostal do rozpaků: přijal přijímač oba pakety, nebo žádný?

Go-Back-N

Go-Back-N ARQ je protokol posuvného okna s wt> 1, ale opraveno wr= 1. Přijímač odmítá přijmout jakýkoli paket kromě následujícího v pořadí. Pokud dojde ke ztrátě paketu při přenosu, jsou následující pakety ignorovány, dokud není chybějící paket znovu odeslán, minimální ztráta jednoho zpáteční doba. Z tohoto důvodu je neefektivní u odkazů, které často trpí ztrátou paketů.

Příklad nejednoznačnosti

Předpokládejme, že používáme 3bitové pořadové číslo, jaké je typické pro HDLC. To dává N=23= 8. Od té doby wr= 1, musíme omezit wt≤7. Je to proto, že po přenosu 7 paketů existuje 8 možných výsledků: Kamkoli od 0 do 7 paketů mohlo být úspěšně přijato. Toto je 8 možností a vysílač potřebuje v potvrzení dostatek informací, aby je všechny rozlišil.

Pokud vysílač poslal 8 paketů bez čekání na potvrzení, mohl by se ocitnout v podobné situaci jako v případě stop-and-wait: znamená potvrzení, že všech 8 paketů bylo přijato úspěšně, nebo žádný z nich?

Selektivní opakování

Nejobecnějším případem protokolu posuvného okna je Selektivní opakování ARQ. To vyžaduje mnohem schopnější přijímač, který dokáže přijímat pakety s pořadovými čísly vyššími než aktuální nr a ukládejte je, dokud se mezera nevyplní.

Výhodou však je, že není nutné zahodit následující správná data na jednu dobu zpáteční cesty, než může být vysílač informován, že je nutný opakovaný přenos. To je proto výhodné pro odkazy s nízkou spolehlivostí a / nebo vysokou produkt se zpožděním šířky pásma.

Velikost okna wr musí být pouze větší než počet po sobě ztracené pakety, které lze tolerovat. Malé hodnoty jsou tedy populární; wr= 2 je běžné.

Příklad nejednoznačnosti

Mimořádně populární HDLC protokol používá 3-bitové pořadové číslo a má volitelné opatření pro selektivní opakování. Pokud však má být použito selektivní opakování, požadavek, že nt+nr ≤ 8 musí být udržováno; -li wr se zvýší na 3, wt musí být snížena na 6.

Předpokládejme to wr = 2, ale používá se nemodifikovaný vysílač s wt = 7, jak se obvykle používá u varianty HD-back-N-back-N. Dále předpokládejme, že přijímač začíná nr =ns =0.

Nyní předpokládejme, že přijímač vidí následující sérii paketů (všechny modulo 8):

0 1 2 3 4 5 6 (pauza) 0

Protože wr = 2, přijímač přijme a uloží finální paket 0 (myslí si, že je to paket 8 v sérii), zatímco požaduje opakovaný přenos paketu 7. Je však také možné, že vysílač nepřijal žádná potvrzení a má znovu vyslaný paket 0. V tomto druhém případě by přijímač přijal nesprávný paket jako paket 8.

Řešením je omezení vysílače wt ≤6. S tímto omezením přijímač ví, že pokud by byla ztracena všechna potvrzení, vysílač by se po paketu 5 zastavil. Když přijme paket 6, může přijímač odvodit, že vysílač přijal potvrzení pro paket 0 (vysílač nA ≥1), a tedy následující paket s číslem 0 musí být paketem 8.

Rozšíření

Existuje mnoho způsobů, jak lze protokol rozšířit:

  • Výše uvedené příklady předpokládaly, že pakety nejsou při přenosu nikdy přeuspořádány; při přepravě se mohou ztratit (detekce chyb dělá korupci ekvivalentní ztrátě), ale nikdy se neobjeví mimo provoz. Protokol lze rozšířit tak, aby podporoval přeskupování paketů, pokud lze ohraničit vzdálenost; modul pořadového čísla N musí být rozšířena o maximální vzdálenost nesprávného řazení.
  • Je možné nepotvrdit každý paket, pokud je nakonec zasláno potvrzení, pokud dojde k pauze. Například TCP normálně potvrzuje každý druhý paket.
    • Je běžné okamžitě informovat vysílač, pokud je detekována mezera v sekvenci paketů. HDLC má k tomu speciální paket REJ (reject).
  • Velikost vysílacího a přijímacího okna se může během komunikace změnit, pokud jejich součet zůstane v limitu N. Normálně jsou každému přiřazeny maximální hodnoty, které respektují tento limit, ale pracovní hodnota v daném okamžiku může být menší než maximum. Zejména:
    • Je běžné zmenšit velikost vysílacího okna, aby se zpomalil přenos, aby odpovídal rychlosti spoje, a vyhnout se nasycení nebo dopravní zácpy.
    • Jedno společné zjednodušení selektivního opakování je tzv. SREJ-REJ ARQ. Toto funguje s wr= 2 a ukládá do vyrovnávací paměti pakety následující po mezeře, ale umožňuje pouze jeden ztracený paket; při čekání na ten balíček, wr= 1 a pokud dojde ke ztrátě druhého paketu, nebudou žádné další pakety ukládány do vyrovnávací paměti. To poskytuje většinu výhody výkonu plného protokolu selektivního opakování s jednodušší implementací.

Viz také

Reference

  1. ^ Peterson, Larry L. & Davie, Bruce S. "Počítačové sítě: systémový přístup ", Morgan Kaufmann, 2000. ISBN  1-55860-577-0
  • Comer, Douglas E. „Internetworking with TCP / IP, Volume 1: Principles, Protocols, and Architecture“, Prentice Hall, 1995. ISBN  0-13-216987-8
  • Peterson, Larry L. & Davie, Bruce S. „Počítačové sítě: systémový přístup“, Morgan Kaufmann, 2000. ISBN  1558605142

externí odkazy