Děravý kbelík - Leaky bucket
The děravý kbelík je algoritmus založený na analogie jak a Kbelík s konstantou unikat přeteče, pokud průměrný rychlost, při které je voda nalita, překračuje rychlost, při které kbelík uniká, nebo pokud je najednou nalito více vody, než je kapacita kbelíku. Může být použit k určení, zda určitá posloupnost diskrétních událostí vyhovuje na definované limity jejich průměrných a špičkových rychlostí nebo frekvencí, např. omezit akce spojené s těmito událostmi na tyto sazby nebo je odložit, dokud neodpovídají sazbám. Může být také použit ke kontrole shody nebo omezení pouze na průměrnou rychlost, tj. K odstranění jakékoli odchylky od průměru.
Používá se v přepínáním paketů počítačové sítě a telekomunikace sítě v obou dopravní policie a utváření provozu z datové přenosy, ve formě balíčky,[poznámka 1] na definované limity na šířka pásma a roztržení (míra nerovností nebo odchylek v provoz tok). Může být také použit jako plánovací algoritmus k určení načasování přenosů, které budou v souladu s limity stanovenými pro šířku pásma a rychlost použitou sítí: viz plánovač sítě.[1][2][3][4] Verze děravého kbelíku, obecný algoritmus buněčné rychlosti, se doporučuje pro asynchronní režim přenosu (ATM) sítě[5] v Usage / Network Parameter Control na uživatelsko-síťová rozhraní nebo mezisíťová rozhraní nebo rozhraní mezi sítěmi na chránit síť z nadměrných úrovní provozu na připojeních směrovaných přes ni. Rovněž lze použít obecný algoritmus buněčné rychlosti nebo ekvivalent tvar přenosy a karta síťového rozhraní do sítě ATM (tj. na straně uživatele rozhraní uživatelské sítě), např. na úrovně pod úrovněmi nastavenými pro Usage / Network Parameter Control v síti, aby se zabránilo tomu, že podnikne kroky k dalšímu omezení tohoto připojení. Algoritmus děravého kbelíku se používá také v počítačích děravého kbelíku, např. zjistit, kdy průměrná nebo špičková rychlost náhodný nebo stochastický události nebo stochastické procesy, jako jsou poruchy nebo poruchy, překračují definované limity.
Alespoň některé implementace děravého kbelíku jsou zrcadlovým obrazem Kbelík žetonů algoritmus a bude, vzhledem k ekvivalentním parametrům, určovat přesně stejnou posloupnost událostí tak, aby odpovídala nebo neodpovídala stejným limitům. Existují však alespoň dva různé popisy děravého kbelíku, které mohou a mohly způsobit zmatek.[1][2][6]
Přehled
V literatuře jsou popsány dva různé způsoby použití této analogie děravého kbelíku.[1][2][3][4] Ty dávají to, co se jeví jako dva různé algoritmy, oba jsou označovány jako algoritmus děravého kbelíku a obecně bez odkazu na druhou metodu. To vedlo k nejasnostem ohledně toho, co je algoritmus děravého kbelíku a jaké jsou jeho vlastnosti.
V jedné verzi aplikace analogie je analogem kbelíku čítač nebo proměnná, oddělená od toku provozu nebo plánování událostí.[1][3][4] Tento čítač se používá pouze ke kontrole, zda provoz nebo události odpovídají limitům: Počítadlo se zvyšuje, když každý paket dorazí do místa, kde se provádí kontrola nebo dojde k události, což je ekvivalentní způsobu, jakým je voda přerušovaně přidávána kyblík. Počitadlo je také sníženo pevnou rychlostí, ekvivalentní způsobu úniku vody z kbelíku. Výsledkem je, že hodnota v počitadle představuje hladinu vody v analogickém kbelíku. Pokud počitadlo zůstane pod stanovenou mezní hodnotou, když dorazí paket nebo dojde k události, tj. Kbelík nepřetéká, znamená to, že je v souladu s limity šířky pásma a burstiness nebo s limity událostí průměrné a špičkové rychlosti. Takže v této verzi je analoga vody nesena pakety nebo událostmi, přidána do kbelíku při jejich příchodu nebo výskytu a poté uniká pryč. Tato verze se zde označuje jako děravý kbelík jako metr.
Ve druhé verzi je analogem kbelíku fronta v toku provozu.[2] Tato fronta se používá k přímé kontrole tohoto toku: Pakety se do fronty zadávají ihned po příjezdu, což odpovídá vodě přidané do kbelíku. Tyto pakety jsou poté odebrány z fronty (kdo dřív přijde, ten dřív mele ), obvykle za pevnou sazbu, např. pro další převod, což odpovídá vodě vytékající z lopaty. Výsledkem je, že rychlost obsluhy fronty přímo řídí další přenosovou rychlost provozu. Ukládá tedy shodu, nikoli ji kontrolovat, a kde je fronta obsluhována pevnou rychlostí (a kde jsou pakety stejné délky), výsledný tok dat nutně postrádá burstiness nebo jitter. V této verzi je tedy samotný provoz analogií vody procházející kbelíkem. Není jasné, jak lze tuto verzi aplikace analogie použít ke kontrole rychlostí diskrétních událostí. Tato verze se zde označuje jako děravý kbelík jako fronta.
Děravý kbelík jako metr je přesně ekvivalentní (zrcadlový obraz) kbelík na žetony algoritmus, tj. proces přidávání vody do propustného kbelíku přesně odráží postup odstraňování tokenů z kbelíku s tokeny, když dorazí vyhovující balíček, proces úniku vody z propustného kbelíku přesně odráží proces pravidelného přidávání tokenů do kbelíku s tokeny, a test, že netěsný kbelík nebude přetékat, je zrcadlem testu, že kbelík tokenů obsahuje dostatek tokenů a nebude „podtečen“. Díky daným ekvivalentním parametrům tedy tyto dva algoritmy uvidí stejný provoz jako vyhovující nebo nevyhovující. Děravý kbelík jako frontu lze považovat za speciální případ děravého kbelíku jako metr.[6]
Jako metr
Jonathan S. Turner je připsána[7] s původním popisem algoritmu děravého segmentu a popisuje jej takto: „Čítač přidružený každému uživateli vysílajícímu na připojení se zvyšuje vždy, když uživatel pošle paket, a pravidelně se snižuje. Pokud čítač překročí prahovou hodnotu při jeho zvýšení, síť zahodí paket. Uživatel specifikuje rychlost snižování počitadla (to určuje průměrnou šířku pásma) a hodnotu prahové hodnoty (měřítko roztržení) ".[1] Kbelík (analogicky k počítadlu) se v tomto případě používá jako měřič k testování shody paketů, nikoli jako fronta k jejich přímému ovládání.
Další popis toho, co je v podstatě stejnou verzí algoritmu algoritmu, je obecný algoritmus buněčné rychlosti, je dán ITU-T v doporučení I.371 a v Fórum ATM Specifikace UNI.[3][4] Popis, ve kterém je výraz buňka je ekvivalentní k balíček v Turnerově popisu[1] je dána ITU-T následovně: „Nepropustný kbelík v nepřetržitém stavu lze chápat jako kbelík s konečnou kapacitou, jehož skutečný obsah se vypouští nepřetržitou rychlostí 1 jednotky obsahu za časovou jednotku a jehož obsah se zvyšuje o přírůstek T pro každou vyhovující buňku ... Pokud je při příjezdu buňky obsah kbelíku menší nebo roven mezní hodnotě τ, pak se buňka přizpůsobuje; jinak je buňka nekonformní. Kapacita lopaty (horní hranice pultu) je (T + τ)".[4] Tyto specifikace také uvádějí, že vzhledem k jeho konečné kapacitě je obsah kbelíku v době testování shody větší než mezní hodnota, a proto je buňka nevyhovující, pak kbelík zůstane beze změny; to znamená, že voda se jednoduše nepřidává, pokud by došlo k přetečení kbelíku.
David E. McDysan a Darrel L. Spohn poskytují komentář k popisu poskytnutému fórem ITU-T / ATM. V tomto uvádějí „V analogii děravého kbelíku buňky [ATM] ve skutečnosti neprocházejí kbelíkem; pouze kontrola vyhovujícího přijetí ano.“[6] McDysan a Spohn však neobvykle v popisech v literatuře také odkazují na algoritmus děravého segmentu jako na frontu, přičemž pokračují „Všimněte si, že jednou z implementací tvarování provozu je ve skutečnosti nechat buňky protékat segmentem“.[6]
Při popisu fungování verze algoritmu ITU-T se McDysan a Spohn dovolávají „pojmu běžně používaného v teorie front smyšleného "skřítka" ".[6] Tento šotek zkontroluje hladinu v kbelíku a přijme opatření, pokud je hladina nad mezní hodnotou τ : při policejní kontrole (obrázek 2) vytáhne padací dveře, což způsobí spadnutí přicházejícího paketu a zabrání vstupu vody do kbelíku; při tvarování (obrázek 3) tlačí nahoru chlopeň, která zdržuje přicházející paket a brání mu v dodávání vody, dokud hladina vody v kbelíku neklesne pod τ.
Rozdíl mezi popisy Turnera a fóra ITU-T / ATM spočívá v tom, že Turner je specifický dopravní policie vzhledem k tomu, že fórum ITU-T / ATM je použitelné jak pro policejní řízení, tak pro utváření provozu. Turner také neuvádí, že obsah počitadla by měl být ovlivněn pouze vyhovujícími pakety, a měl by být zvýšen pouze v případě, že by to nezpůsobilo překročení limitu, tj. Turner výslovně neuvádí, že kapacita kbelíku nebo maximální hodnota čítače je konečný. Aby byl Turnerův popis jasně zarovnaný s ITU-T, bylo by nutné změnit prohlášení „Pokud čítač překročí prahovou hodnotu při jejím zvýšení, síť zahodí paket“ na něco jako „Pokud by čítač překročil prahovou hodnotu [ekvivalentní hloubka lopaty, T + τ, v popisu ITU-T] po zvýšení se síť zahodí paket a čítač se nezvýší ", tj. zvýší se pouze tehdy, když je menší nebo roven mezní hodnotě, τ, nebo alespoň T menší než hloubka lopaty v popisu ITU-T.
Zatímco popis poskytnutý Turnerem neuvádí, že na čítač by měly mít vliv pouze vyhovující pakety, je uveden ve smyslu funkce policejní kontroly, kde přílišná horlivost v omezení spojení obsahujícího neshodné pakety nemusí být problém. Opravdu, v některých kontextech, jako např variabilní datový tok (VBR), ztráta kteréhokoli paketu může poškodit celistvost zprávy vyšší vrstvy, např. PDI síťové vrstvy OSI. V takovém případě vyřazení všech následujících paketů poškozeného PDU vrhá zbytečné zatížení sítě. Bylo by však zcela nepřijatelné při utváření provozu pro paket, který prošel testem shody, ovlivnit, jak dlouho může dále dojít ke shodě, tj. Pokud by akt testování následujícího paketu na shodu změnil, jak dlouho má paket aktuálně čekající na shodu čekat. To je přesně to, co by se stalo, kdyby měla být do kbelíku přidána voda z nevyhovujících paketů, protože jakékoli následující nevyhovující pakety by zvýšily hladinu vody, a tak by paket čekající na přizpůsobení počkal déle.
Turner ani ITU-T neřeší problém paketů s proměnnou délkou. Popis podle ITU-T je však pro buňky ATM, které jsou pakety s pevnou délkou, a Turner konkrétně nevylučuje pakety s proměnnou délkou. Proto v obou případech, je-li množství, o které je obsah kbelíku nebo čítač zvýšen pro vyhovující paket, úměrné délce paketu, budou oba odpovídat za délku a umožní algoritmu omezit šířku pásma provozu explicitně spíše než omezení paketové rychlosti. Například kratší pakety by do kbelíku přidaly méně a mohly by tak dorazit v menších intervalech; zatímco delší pakety by přidaly více, a proto musí být odděleny proporcionálně většími intervaly, aby vyhovovaly.
Koncepce provozu
Popis koncepce fungování algoritmu Leaky Bucket Algorithm jako měřiče, který lze použít buď při policejní kontrole, nebo při formování provozu, lze uvést následovně:
- Bucket of fixed capacity, associated with each virtual connection or user, leaks at a fixed rate.
- Pokud je kbelík prázdný, přestane prosakovat.
- Aby se paket přizpůsobil, musí být možné do kbelíku přidat určité množství vody: Specifické množství přidané vyhovujícím paketem může být stejné pro všechny pakety nebo může být úměrné délce paketu.
- Pokud by toto množství vody způsobilo, že kbelík překročí svou kapacitu, paket se neshoduje a voda v kbelíku zůstane beze změny.
Použití
Děravý kbelík jako metr lze použít v obou utváření provozu nebo dopravní policie. Například v sítích ATM se ve formě algoritmu generické rychlosti buňky používá k porovnání šířky pásma a rychlosti provozu na virtuálním kanálu (VC) nebo virtuální cestě (VP) proti stanoveným limitům rychlosti, jakou buňky mohou dorazit a maximální jitter nebo odchylky v intervalech mezi přílety pro VC nebo VP. V provozu policie, buňky, které neodpovídají těmto limitům (nevyhovující buňky), mohou být vyřazeny (zahozeny) nebo mohou být prioritně sníženy (aby došlo k přetížení funkcí pro správu provozu v případě přetížení). Při tvarování provozu jsou buňky zpožděny, dokud se neshodují. Dopravní policie a utváření provozu se běžně používají v UPC / NPC k ochraně sítě před nadměrným nebo nadměrně silným provozem, viz správa šířky pásma a zamezení přetížení. Tvarování provozu se běžně používá v síťových rozhraních v hostitelé zabránit přenosu, který překračuje limity šířky pásma nebo chvění a bude vyřazen funkcemi pro správu provozu v síti. (Vidět plánování (výpočet) a plánovač sítě.)
Algoritmus děravého kbelíku jako měřič lze také použít v počítadle děravého kbelíku k měření rychlosti náhodných nebo stochastické procesy. Čítač Leaky bucket lze použít k detekci, kdy se průměrná nebo špičková rychlost událostí zvýší nad určitou přijatelnou úroveň pozadí, tj. Když kbelík přeteče.[8] Události, které nezpůsobují přetečení, tj. Mají dostatečně nízké rychlosti a jsou dobře distribuovány v čase, však lze ignorovat. Například takové počítadlo netěsných kbelíků lze použít k detekci náhlého výbuchu opravitelných chyb paměti nebo když došlo k postupnému, ale významnému zvýšení průměrné rychlosti, což může naznačovat hrozící selhání,[9] atd.
Použití algoritmu děravého kbelíku v počítadle děravého kbelíku je podobné jako v řízení provozu, protože se používá jako měřič. Události v podstatě nahradí pakety v popisu, přičemž každá událost způsobí, že do kbelíku bude přidáno určité množství vody. Pokud by kbelík v důsledku události přetekl, měla by událost spustit akci spojenou s událostí mimo limity. Některé implementace[8] Zdá se, že paralelní Turnerův popis,[1] v tom, že neexistuje žádné výslovné omezení maximální hodnoty, kterou může počítadlo nabývat, což znamená, že jakmile čítač překročí prahovou hodnotu, nemusí se vrátit do předchozího stavu, dokud neuplyne období výrazně větší než ekvivalent emisního intervalu, což může být zvýšeno tím, co by jinak bylo shodou událostí. Jiné implementace však nemusí zvýšit počitadlo, když je přetečeno, což mu umožňuje správně určit, zda jsou následující události v souladu nebo ne.
Parametry
V případě algoritmu děravého segmentu jako měřiče může být omezením provozu šířka pásma a roztržitost výstupu.[3][4][poznámka 2]
Limit šířky pásma a limit roztržení pro připojení lze specifikovat v a dopravní smlouva. Limit šířky pásma může být specifikován jako paketová nebo snímková frekvence, bajt nebo přenosová rychlost, nebo jako emisní interval mezi pakety. Limitu roztržení lze specifikovat jako a chvění nebo variace zpoždění tolerance, nebo jako a maximální velikost série (MBS).
Na připojení lze použít více sad parametrů kontraktu souběžně pomocí více instancí algoritmu děravého segmentu, z nichž každá může mít šířku pásma a limit burstiness: viz Dual Leaky Bucket Controller.
Emisní interval
Rychlost úniku kbelíku určí limit šířky pásma, který Turner označuje jako průměrnou rychlost[1] a jehož inverze je ITU-T označována jako emisní interval. Nejjednodušší je vysvětlit, o jaký interval jde, když mají pakety pevnou délku. První část tohoto popisu to proto předpokládá a důsledky proměnných délek paketů jsou brány v úvahu samostatně.
Vezměme si kbelík, který je přesně naplněn nahoře předcházejícím provozem, tj. Když již došlo k maximálnímu povolenému roztržení, tj. Maximální počet paketů nebo buněk právě dorazil v minimálním čase, aby stále vyhovovaly šířce pásma a limity chvění. Minimální interval před tím, než se další paket může přizpůsobit, je čas, za který kbelík unikne přesně množství vody dodané paketem, a pokud je paket v té době testován a vyhovuje, bude to přesně ještě jednou naplňovat kbelík . Jakmile je kbelík naplněn, maximální rychlost, kterou pakety mohou vyhovovat, je tedy s tímto intervalem mezi každým paketem.
Soustružník[1] označuje tuto míru jako průměr, z čehož vyplývá, že její inverzní hodnota je průměrný interval. Existují však určité nejasnosti v tom, jaká je průměrná rychlost a interval. Vzhledem k tomu, že pakety mohou dosáhnout jakékoli nižší rychlosti, jedná se spíše o horní hranici než o pevnou hodnotu, takže ji lze v nejlepším případě nazvat maximální pro průměrnou rychlost. Také v době, kdy dojde k maximální roztržení, mohou pakety přicházet s menšími intervaly, a tedy s vyšší rychlostí. Takže pro jakékoli období menší než nekonečno může být skutečná průměrná rychlost (ale nemusí) větší než tato a průměrný interval může být (ale nemusí) menší než emisní interval. Z tohoto důvodu se proto nejednoznačně používá termín emisní interval. Stále však platí, že minimální hodnota, kterou může dlouhodobý průměrný interval trvat, má tendenci být emisním intervalem.
U paketů s proměnnou délkou, kde množství přidané do kbelíku je úměrné délce paketu, se maximální rychlost, s jakou se mohou přizpůsobit, liší podle jejich délky: množství, které kbelík musel uniknout z plné hodnoty, aby se paket přizpůsobil, je množství, které paket přidá, a pokud je to úměrné délce paketu, tak i interval mezi ním a předchozím paketem, který naplnil kbelík. Z tohoto důvodu není možné určit konkrétní emisní interval pro pakety s proměnnou délkou a limit šířky pásma je třeba specifikovat explicitně, v bitech nebo bytech za sekundu.
Tolerance zpoždění variace
Nejjednodušší je vysvětlit, v čem spočívá tato tolerance, když mají pakety pevnou délku. První část tohoto popisu to proto předpokládá a důsledky proměnných délek paketů jsou brány v úvahu samostatně.
ITU-T definuje mezní hodnotu, τ, to je menší než kapacita kbelíku o T (množství, o které se obsah kbelíku zvýší pro každou vyhovující buňku), takže kapacita kbelíku je T + τ. Tato mezní hodnota určuje, o kolik dříve může paket dorazit, než by se normálně očekávalo, kdyby pakety přicházely s přesně emisním intervalem mezi nimi.
Představte si následující situaci: Kbelík uniká rychlostí 1 jednotky vody za sekundu, takže limitní hodnota, τ a množství vody přidané paketem, T, jsou efektivně v jednotkách sekund. Tento kbelík začíná prázdný, takže když balíček dorazí do kbelíku, zcela jej nevyplní přidáním vody Ta kbelík je nyní τ pod jeho kapacitu. Když tedy dorazí další paket, kbelík musí být vyčerpán T – τ aby to vyhovovalo. Interval mezi těmito dvěma pakety tedy může být až τ méně než T.
To se vztahuje na více paketů v sekvenci: Představte si následující: Vědro začíná znovu prázdné, takže první přijatý paket musí odpovídat. Vědro se poté po několika vyhovujících paketech úplně zaplní, N, dorazili v minimální možné době, aby se přizpůsobili. Za poslední ( Nth) paket, aby vyhovoval, kbelík musel mít dostatek vody z předchozího N - 1 balíček ((N – 1) * T v sekundách), aby byla přesně na mezní hodnotě τ v tuto chvíli. Proto uniklá voda je (N – 1)T – τ, který, protože únik je jedna jednotka za sekundu, trval přesně (N – 1)T – τ sekund k úniku. Tedy nejkratší doba, za kterou všichni N pakety mohou přijít a vyhovět je (N – 1)T – τ sekund, což je přesně τ méně než čas, který by trvalo, kdyby pakety přicházely přesně v emisním intervalu.
Pakety však mohou dorazit pouze v intervalech kratších než T kde kbelík není naplněn předchozím paketem. Pokud ano, pak kbelík musel být vyčerpán o celé množství T než vyhoví další balíček. Jakmile byla tato tolerance vyčerpána pakety, které dorazily na méně než T, následující snímky musí dorazit v intervalech minimálně T. Mohou však dorazit ve větších intervalech, když kbelík nebudou naplněni. Když k tomu dojde, pakety mohou opět dorazit s intervaly menšími než T dokud se tolerance znovu nevyčerpá. Jelikož však kbelík přestane prosakovat, když je prázdný, vždy existuje limit (τ) na to, jak velkou toleranci mohou tyto intervaly nabýt větší než T, nicméně, mnohem větší než T mohou být, nebo je jich však mnoho.
Od mezní hodnoty τ definuje, o kolik dříve může paket dorazit, než by se dalo očekávat, je to limit rozdílu mezi maximálním a minimálním zpožděním od zdroje do bodu, kde se provádí test shody (za předpokladu, že pakety jsou generovány bez chvění). Proto je použití termínu Tolerance odchylky buněčného zpoždění (CDVt) pro tento parametr v ATM.
Možným zdrojem variace zpoždění je například situace, kdy je na výstupu přepínače společně spojeno několik spojení (proud paketů). Za předpokladu, že součet šířek pásma těchto připojení je menší než na výstupu, lze případně přenést všechny přicházející pakety. Pokud jsou však jejich příjezdy nezávislé, např. protože dorazí na různé vstupy přepínače, pak několik může dorazit na nebo téměř současně. Vzhledem k tomu, že výstup může vysílat pouze jeden paket najednou, ostatní musí být zařazeni do fronty do vyrovnávací paměti, dokud není na řadě jejich přenos. Tato vyrovnávací paměť poté zavádí další zpoždění mezi paketem přicházejícím na vstup a přenášeným výstupem a toto zpoždění se liší v závislosti na tom, kolik dalších paketů je již ve frontě ve vyrovnávací paměti. Podobná situace může nastat na výstupu hostitele (v NIC), když má více paketů stejné nebo podobné časy vydání, a toto zpoždění lze obvykle modelovat jako zpoždění ve virtuální výstupní vyrovnávací paměti.
U paketů s proměnnou délkou, kde je množství vody přidané daným paketem úměrné jeho délce, τ nelze považovat za omezení toho, jak plný může být kbelík, když přijde paket, protože se to liší v závislosti na velikosti paketu. Čas potřebný k odtoku z této úrovně do prázdné je však stále o kolik dříve může paket dorazit, než se očekává, když jsou pakety přenášeny na hranici šířky pásma. Toleruje se tedy stále maximální změna zpoždění přenosu do bodu, kde se aplikuje zkouška shody, a tedy tolerance maximální změny zpoždění.
Maximální velikost série
Mezní hodnota nebo tolerance odchylky zpoždění také řídí, kolik paketů může dorazit do série, určeno přebytečnou hloubkou bloku nad kapacitu požadovanou pro jeden paket. Proto je MBS také měřítkem roztržení nebo chvění a je možné určit roztržnost jako MBS a odvodit mezní hodnotu τ z toho nebo jej specifikovat jako toleranci / mezní hodnotu odchylky kolísání / zpoždění a z toho odvodit MBS.
Výbuch nebo shluk paketů může dosáhnout vyšší rychlosti, než je určeno emisním intervalem T. Může to být rychlost linky připojení fyzické vrstvy, když pakety v dávce dorazí zády k sobě. Stejně jako v ATM však může být tolerance aplikována na nižší sazbu, v tom případě Udržitelná buněčná rychlost (SCR) a shluk paketů (buněk) může dosáhnout vyšší rychlosti, ale menší, než je rychlost linky fyzické vrstvy, v tom případě Maximální rychlost buněk (PCR). MBS pak může být počet buněk potřebných k přenosu paketu vyšší vrstvy (viz segmentace a opětovná montáž ), kde jsou pakety přenášeny s maximální šířkou pásma určenou SCR a buňky v paketech jsou přenášeny při PCR; což umožňuje, aby poslední buňka paketu a samotný paket dorazily podstatně dříve, než by tomu bylo, kdyby byly buňky odeslány na SCR: doba přenosu = (MBS-1) / PCR spíše než (MBS-1) / SCR. Toto prasknutí při PCR výrazně zvyšuje zátěž sdílených zdrojů, např. přepínat výstupní vyrovnávací paměti, než přenos na SCR, a je tedy pravděpodobnější, že bude mít za následek přetečení vyrovnávací paměti a přetížení sítě. Klade však na tyto zdroje menší zátěž, než jakou by přenášela na SCR s mezní hodnotou, τSCR, který umožňuje přenášet buňky MBS a přicházet zády k sobě při liniové rychlosti.
Pokud je mezní hodnota dostatečně velká, může několik paketů dorazit ve shluku a stále vyhovovat: pokud kbelík začíná od prázdného, přidá se první přijatý paket T, ale pokud v době, kdy dorazí další paket, je obsah níže τ, bude to také vyhovovat. Za předpokladu, že každý balíček trvá δ přijet, pak pokud τ (vyjádřeno jako čas potřebný k vyprázdnění kbelíku z mezní hodnoty) je roven nebo větší než emisní interval po odečtení minimálního času mezi příjezdy, T – δ, druhý paket bude vyhovovat, i když přijde jako shluk s prvním. Podobně, pokud τ je rovno nebo větší než (T – δ) × 2, pak mohou 3 balíčky dorazit v sérii atd.
Maximální velikost této série, M, lze vypočítat z emisního intervalu, T; maximální tolerance chvění, τ; a čas potřebný k přenosu / přijetí paketu, δ, jak následuje:[3]
Stejně tak minimální hodnota tolerance chvění τ který dává konkrétní MBS lze vypočítat z MBS následujícím způsobem:[3]
V případě ATM, kde se technicky MBS týká pouze tolerance SCR, ve výše uvedené rovnici čas potřebný k přijetí každého paketu, δ, je emisní interval pro buňky v PCR TPCRa emisní interval, T, je emisní interval pro SCR TSCR. Tam, kde MBS má být počet buněk potřebných k přepravě segmentovaného paketu, je výše uvedená limitní hodnota τ, by mělo být, že pro SCR τSCR. Avšak v UNI nebo NNI, kde budou buňky v PCR vystaveny zpožděným změnám, by to měla být mezní hodnota pro SCR plus hodnota pro PCR τSCR + τPCR.
U paketů s proměnnou délkou bude maximální velikost série záviset na délkách paketů v sérii a pro maximální velikost série nebude existovat jediná hodnota. Je však možné určit celkovou délku shluku v bajtech, z bajtové rychlosti vstupního proudu, ekvivalentní bajtové rychlosti úniku a hloubky segmentu.
Srovnání s algoritmem segmentu tokenů
Algoritmus děravého kbelíku je někdy v kontrastu s kbelík na žetony algoritmus. Nicméně výše koncepce provozu pro děravý kbelík jako metr lze přímo porovnat s algoritmem kbelíku tokenů, jehož popis je uveden v tomto článku takto:
- Token je přidán do kbelíku každý 1 /r sekundy.
- Kbelík pojme maximálně b žetony. Pokud token dorazí, když je kbelík plný, je zahozen.
- Když paket (síťová vrstva PDU ) [sic ][poznámka 1] dorazí „n“ bajtů, n tokeny jsou odebrány z bloku a paket je odeslán do sítě.
- Pokud méně než n tokeny jsou k dispozici, z kbelíku nejsou odstraněny žádné tokeny a paket je považován za nevyhovující.
To lze srovnat s konceptem provozu, opakovaným shora:
- Bucket of fixed capacity, associated with each virtual connection or user, leaks at a fixed rate.
- Pokud je kbelík prázdný, přestane prosakovat.
- Aby vyhovoval paket, musí být možné do kbelíku přidat určité množství vody: Specifické množství přidané vyhovujícím paketem může být stejné pro všechny pakety nebo může být úměrné délce paketu.
- Pokud by toto množství vody způsobilo, že kbelík překročí svou kapacitu, paket neodpovídá a voda v kbelíku zůstane nezměněna.
Jak je vidět, tyto dva popisy jsou v podstatě zrcadlovými obrazy jeden druhého: jeden pravidelně přidává něco do kbelíku a něco odnáší za přizpůsobení paketů až k limitu nuly; druhý pravidelně odebírá a přidává pro vyhovující pakety až do limitu kapacity kbelíku. Je implementace, která přidává tokeny pro vyhovující paket a odstraňuje je pevnou rychlostí, implementací děravého kbelíku nebo kbelíku tokenů? Podobně, který algoritmus se používá v implementaci, která odstraňuje vodu pro vyhovující paket a přidává vodu pevnou rychlostí? Ve skutečnosti jsou oba skutečně stejné, tj. Implementace propustného kbelíku i kbelíku tokenů, protože se jedná o stejný základní algoritmus popsaný odlišně. To vysvětluje, proč, vzhledem k ekvivalentním parametrům, oba algoritmy uvidí přesně stejné pakety jako vyhovující nebo nevyhovující. Rozdíly ve vlastnostech a výkonu implementací algoritmů děravého a tokenového segmentu tedy vyplývají výhradně z rozdílů v implementacích, tj. Nevycházejí z rozdílů v základních algoritmech.
Je třeba si uvědomit, že algoritmus děravého kbelíku, když se používá jako měřič, může umožnit vyhovující výstupní proud paketů s chvěním nebo roztržením, lze jej použít v policejním provozu i tvarování a lze jej implementovat pro pakety s proměnnou délkou.
Jako fronta
Děravý kbelík jako fronta je v podstatě způsob, jak popsat jednoduchý FIFO vyrovnávací paměť nebo fronta, která je obsluhována pevnou rychlostí, aby se odstranilo roztržení nebo chvění. Popis je uveden v Andrew S. Tanenbaum, ve (starší verzi) své knihy Počítačové sítě jako „Děravý kbelík se skládá z omezené fronty. Když přijde paket, je-li ve frontě místo, přidá se do fronty; jinak se zahodí. Za každých hodin zaškrtněte, aby byl vyslán jeden paket (pokud fronta není prázdná) ".[2] Implementace děravého segmentu jako fronty je proto vždy formou funkce tvarování provozu.
Jak je vidět, tato implementace je omezena tím, že pakety jsou přenášeny pouze pevnou rychlostí. Aby to podtrhl, Tanenbaum rovněž uvádí, že „Algoritmus děravého segmentu vynucuje rigidní výstupní vzor průměrnou rychlostí, bez ohledu na to, jak náročný je [vstupní] provoz“.[10] Toto tvrzení však platí pouze striktně, pokud fronta nezůstane prázdná: pokud je průměrná míra příjezdu menší než rychlost hodinových tiků, nebo pokud je vstup dostatečně roztržitý, aby ztráty snížily rychlost zbytku pod taktovací frekvence hodin (tj. mezery ve vstupním proudu jsou dostatečně dlouhé a fronta je dostatečně malá, aby se mohla vyprázdnit), ve výstupním proudu budou mezery.
Dalším omezením je, že netěsný segment jako funkce tvarování provozu ve frontě přenáší pakety pouze na klíšťatech; proto, pokud je používán v síti, ekvivalentní k UPC a NPC, také ukládá pevnou fázi dalšího přenosu paketů. Vzhledem k tomu, že při použití měřiče děravého kbelíku k řízení dalšího přenosu je paket vysílán, jakmile se shoduje, tj. Relativně k předchozímu, nebo, pokud již vyhovuje, čas svého příjezdu; ne podle libovolných místních hodin. Zvráceně, v souvislosti se zpožděním přenosu, toto uložení pevné fáze, která se může časem lišit od uložení jinak vyhovujícího proudu vstupního paketu, představuje změnu zpoždění, a tedy i chvění. Chvění způsobené tímto konkrétním způsobem bylo možné pozorovat pouze tehdy, když se zpoždění měří jako doba přechodu mezi dvěma samostatnými měřicími body, přičemž jedna z obou stran netěsného kbelíku je funkcí tvarování fronty. However, in the context of real-time data transmissions, it is this end-to-end delay that determines the latency of received data. Hence, the leaky bucket as a queue is unsuitable for traffic shaping real-time transmissions.
Limiting variable length packets using the leaky bucket algorithm as a queue is significantly more complicated than it is for fixed length packets. Tanenbaum gives a description of a "byte-counting" leaky bucket for variable length packets as follows: "At each tick, a counter is initialized to n. If the first packet on the queue has fewer bytes than the current value of the counter, it is transmitted, and the counter is decremented by that number of bytes. Additional packets may also be sent, as long as the counter is high enough. When the counter drops below the length of the next packet on the queue, transmission stops until the next tick, at which time the residual byte count is reset [to n] and the flow can continue".[2] As with the version for fixed length packets, this implementation has a strong effect on the phase of transmissions, resulting in variable end-to-end delays, and unsuitability for real-time traffic shaping.
Použití
The leaky bucket as a queue can only be used in shaping traffic to a specified bandwidth with no jitter in the output.[10] It may be used within the network, e.g. as part of bandwidth management, but is more appropriate to traffic shaping in the network interfaces of hosts.
Parametry
In the case of the leaky bucket algorithm as a queue, the only defined limit for this algorithm is the bandwidth of its output.[10][poznámka 2]
The bandwidth limit for the connection may be specified in a dopravní smlouva. A bandwidth limit may be specified as a packet or frame rate, a byte or přenosová rychlost, nebo jako emission interval between the packets.
Inefficiency
The implementation of the leaky-bucket as a queue does not use available network resources efficiently. Because it transmits packets only at fixed intervals, there will be many instances when the traffic volume is very low and large portions of network resources (bandwidth in particular) are not being used. Therefore no mechanism exists in the leaky-bucket implementation as a queue to allow individual flows to burst up to port speed, effectively consuming network resources at times when there would not be resource contention in the network. Implementations of the token bucket and leaky bucket as a meter do, however, allow output traffic flows to have bursty characteristics.
Comparison between the two versions
Analysis of the two versions of the leaky bucket algorithm shows that the version as a queue is a special case of the version as a meter.
Imagine a traffic shaping function for fixed length packets that is implemented using a fixed length queue, forming a delay element, which is serviced using a leaky bucket as a meter. Imagine also that the bucket in this meter has a depth equal to the amount added by a packet, i.e. has a limit value, τ, of zero. However, the conformance test is only performed at intervals of the emission interval, when the packet at the head of the queue is transmitted and its water is added. This water then leaks away during the next emission interval (or is removed just prior to performing the next conformance test), allowing the next packet to conform then or at some subsequent emission interval. The service function can also be viewed in terms of a token bucket with the same depth, where enough tokens for one packet are added (if the bucket is not full) at the emission intervals. This implementation will then receive packets with a bursty arrival pattern (limited by the queue depth) and transmit them on at intervals that are always exact (integral) multiples of the emission interval.
However, the implementation of the leaky bucket as a meter (or token bucket) in a traffic shaping function described above is an exact equivalent to the description of the leaky bucket as a queue:[2] the delay element of the meter version is the bucket of the queue version; the bucket of the meter version is the process that services the queue, and the leak is such that the emission interval is the same as the tick interval. Therefore for fixed length packets, the implementation of the leaky bucket as a queue is of a special case of a traffic shaping function using a leaky bucket (or token bucket) as a meter in which the limit value, τ, is zero and the process of testing conformance is performed at the lowest possible rate.
The leaky bucket as a queue for variable packet lengths can also be described as equivalent to a special case of the leaky bucket as a meter. The suggested implementation[2] can, like the fixed length implementation, be seen as traffic shaping function in which the queue is a delay element, rather than the bucket, and the function that services the queue is, in this case, explicitly given as a token bucket: it is decremented for conforming packets and incremented at a fixed rate. Hence, as the leaky bucket as a meter and token bucket are equivalent, the leaky bucket as a queue for variable packet lengths is also a special case of a traffic shaping function using a leaky bucket (or token bucket) as a meter.
There is an interesting consequence of seeing the leaky bucket as a queue for variable packet lengths as a specific implementation of the token bucket or leaky bucket as a meter in traffic shaping. This is that the bucket of the meter has a depth, n, and, as is always the case with the token bucket, this depth determines the burstiness of the output traffic (perhaps in relation to the average or minimum number of tokens required by the packets). Hence, it is possible to quantify the burstiness of the output of this "byte counting" leaky bucket as a meter, unless all packets are of the maximum length when it becomes pointless. However, this ability to define a burstiness for the output is in direct contradiction to the statement that the leaky bucket (as a queue) necessarily gives an output with a rigid rate, no matter how bursty the input.
Viz také
Poznámky
- ^ A b In traffic management, the leaky bucket is normally applied to the equivalent of ISO -OSI model vrstva 2 Vrstva datového spojení PDUs, např. bankomat buňky a Ethernetové rámečky, které se nazývají rámy. It may be argued then that the description of this algorithm should be given in terms of rámy ne balíčky, which are, in the ISO-OSI 7 layer model, layer 3 Síťová vrstva PDU. However, the term packet is commonly used generically in the descriptions of this algorithm in the literature, and this convention is also applied here. It is not, however, intended to imply that the leaky bucket algorithm is applied exclusively to Network Layer PDUs.
- ^ A b Traffic shaping functions include a queue that is necessarily of finite size. Hence, if he input stream exceeds some level of burstiness dependent on the length of the queue or consistently exceeds the bandwidth limit being imposed on the output stream, the queue will overflow and packets will (normally) be discarded: see Traffic shaping#Overflow condition. Therefore, traffic shaping functions can be seen as applying traffic policing to the input connection and traffic shaping to the output. They should, therefore, take a parameter for the burstiness limit on the input additional to that or those for the leaky bucket. However, this input burstiness limit may be defaulted to a value that is not expected to impact on normal traffic (the queue is assumed to be deep enough for all normal circumstances), and not always specified explicitly.
Reference
- ^ A b C d E F G h i Turner, J., New directions in communications (or which way to the information age?). IEEE Communications Magazine 24 (10): 8–15. ISSN 0163-6804, 1986.
- ^ A b C d E F G h Andrew S. Tanenbaum, Computer Networks, Fourth Edition, ISBN 0-13-166836-6, Prentice Hall PTR, 2003., page 401.
- ^ A b C d E F G ATM Forum, The User Network Interface (UNI), v. 3.1, ISBN 0-13-393828-X, Prentice Hall PTR, 1995.
- ^ A b C d E F ITU-T, Řízení provozu a řízení přetížení v B ISDNDoporučení I.371, Mezinárodní telekomunikační unie, 2004, příloha A, strana 87.
- ^ ITU-T, Řízení provozu a řízení přetížení v B ISDN, Recommendation I.371, International Telecommunication Union, 2004, page 17
- ^ A b C d E McDysan, David E. and Spohn, Darrel L., ATM : Theory and Application, ISBN 0-07-060362-6, McGraw-Hill series on computer communications, 1995, pages 358–9.
- ^ Andrew S. Tanenbaum, Computer Networks, Fourth Edition, ISBN 0-13-166836-6, Prentice Hall PTR, 2003, Page 400.
- ^ A b http://encyclopedia2.thefreedictionary.com/leaky+bucket+counter.
- ^ Intel, Intel Server Board S5400SF: Technical Product SpecificationZáří 2007, http://download.intel.com/support/motherboards/server/s5400sf/sb/s5400sf_tps_rev2_01.pdf.
- ^ A b C Andrew S. Tanenbaum, Computer Networks, Fourth Edition, ISBN 0-13-166836-6, Prentice Hall PTR, 2003, page 402.