Pracovní sada - Working set - Wikipedia

Pracovní sada je koncept v počítačová věda který definuje množství paměti, které a proces vyžaduje v daném časovém intervalu.

Definice

Peter Denning (1968) definuje „pracovní soubor informací a proces v čase být shromažďování informací, na které odkazuje proces během časového intervalu procesu ".[1]Typicky se příslušné jednotky informací považují za stránky paměti. Toto je navrhováno jako aproximace sady stránek, ke kterým bude proces v budoucnu přistupovat (řekněme během následujících časových jednotek) a konkrétněji se navrhuje, aby ukazoval, jaké stránky by měly být uchovávány v hlavní paměti, aby bylo možné dosáhnout největšího pokroku při provádění tohoto procesu.

Odůvodnění

Efekt volby toho, jaké stránky mají být uchovávány v hlavní paměti (na rozdíl od bytí stránkovaný do pomocného úložiště) je důležité: pokud je v hlavní paměti uloženo příliš mnoho stránek procesu, může být najednou připraveno méně dalších procesů. Pokud je v hlavní paměti příliš málo stránek procesu, pak jeho chyba stránky frekvence se značně zvyšuje a počet aktivních (pozastavených) procesů aktuálně prováděných v systému se blíží nule.

The model pracovní sady uvádí, že proces může být v RAM právě tehdy, pokud všechny stránky, které aktuálně používá (často aproximované naposledy použitými stránkami), mohou být v paměti RAM. Model je modelem všeho nebo nic, což znamená, že pokud se stránky, které potřebuje použít, zvýší a v paměti RAM nebude místo, proces se vymění z paměti, aby se uvolnila paměť pro další procesy.

Často těžce načten počítač má tolik procesů ve frontě, že pokud by všechny procesy mohly běžet pro jeden plánování časový plátek, odkazovali by na více stránek, než je RAM, což by způsobilo „mlátit ".

Výměnou některých procesů z paměti je výsledkem to, že procesy - dokonce i procesy, které byly dočasně odstraněny z paměti - se dokončí mnohem dříve, než kdyby se počítač pokusil spustit všechny najednou. Procesy také dokončí mnohem dříve, než by byly, pokud by počítač běžel po dokončení pouze jednoho procesu, protože umožňuje spuštění dalších procesů a dosažení pokroku v době, kdy jeden proces čeká na pevném disku nebo jiném globálním zdroji.

Jinými slovy, strategie pracovní sady brání mlácení při zachování nejvyšší možné úrovně multiprogramování. Optimalizuje tak využití a propustnost procesoru.

Implementace

Hlavní překážkou při implementaci modelu pracovní sady je sledování pracovní sady. Okno pracovní sady je pohyblivé okno. Při každém odkazu na paměť se na jednom konci objeví nová reference a na druhém konci nejstarší reference. Stránka je v pracovní sadě, pokud je na ni odkazováno v okně pracovní sady.

Aby se zabránilo režii vedení seznamu posledních k odkazované stránky, pracovní sada je často implementována sledováním času t posledního odkazu a vzhledem k tomu, že pracovní sadou jsou všechny stránky odkazované v určitém časovém období.

Pracovní sada není algoritmus nahrazení stránky, ale algoritmy nahrazování stránek mohou být navrženy tak, aby odstranily pouze stránky, které nejsou v pracovní sadě pro konkrétní proces. Jedním z příkladů je upravená verze hodinový algoritmus nazývá WSClock.

Varianty

Pracovní sadu lze rozdělit na kód pracovní souprava a data pracovní sada. Tento rozdíl je důležitý, když jsou kód a data na příslušné úrovni hierarchie paměti oddělené, jako kdyby buď pracovní sada se nevejde na tuto úroveň hierarchie, dojde k výprasku. Kromě samotného kódu a dat na systémech s virtuální paměť, paměťová mapa (z virtuální paměti do fyzické paměti) položky stránek pracovní sady musí být uloženy v mezipaměti překladová vyrovnávací paměť (TLB) pro efektivní postup procesu. Tento rozdíl existuje, protože kód a data se ukládají do mezipaměti v malých blocích (řádky mezipaměti ), nikoli celé stránky, ale vyhledávání adres se provádí na úrovni stránky. Takže i když se pracovní sady kódu a dat vejdou do mezipaměti, pokud jsou pracovní sady rozděleny na mnoho stránek, pracovní sada virtuální adresy nemusí zapadnout do TLB, což způsobí mlácení TLB.

Analogy pracovní sady existují pro jiné omezené zdroje, nejvýznamněji procesy. Pokud sada procesů vyžaduje častou interakci mezi více procesy, pak má a procesní pracovní sada to musí být naplánováno za účelem pokroku:[2]

paralelní programy mají a procesní pracovní sada to musí být naplánováno (naplánováno na současné spuštění), aby paralelní program dosáhl pokroku.

Pokud procesy nejsou naplánovány současně - například pokud existují dva procesy, ale pouze jedno jádro, na kterém je lze provádět -, mohou procesy postupovat pouze rychlostí jedné interakce za časový úsek.

Mezi další zdroje patří úchyty pilníků nebo síťové zásuvky - například kopírování jednoho souboru do druhého se nejjednodušší provádí pomocí dvou popisovačů souborů: jednoho pro vstup, druhého pro výstup, a má tedy velikost „pracovní sady pro zpracování souborů“ dvě. Pokud je k dispozici pouze jeden popisovač souboru, kopírování lze stále provádět, ale vyžaduje získání popisovače souboru pro vstup, čtení z něj (řekněme do vyrovnávací paměti), jeho uvolnění, poté získání popisovače souboru pro výstup, zápis do něj, uvolněním, následným získáním popisovače vstupního souboru a opakováním. Podobně může server vyžadovat mnoho soketů a pokud je omezený, bude muset opakovaně uvolňovat a znovu získávat sokety. Spíše než výprask, tyto prostředky jsou obvykle Požadované pro program, a pokud nemůže získat dostatek zdrojů, jednoduše selže.

Viz také

Reference

  1. ^ Denning, Peter J. (1968). "Model pracovní sady pro chování programu" (PDF). Komunikace ACM. 11 (5): 323–333. doi:10.1145/363095.363141.
  2. ^ Ousterhout, J. K. (1982). „Techniky plánování pro souběžné systémy“ (PDF). Sborník příspěvků ze třetí mezinárodní konference o distribuovaných výpočetních systémech: 22–30.CS1 maint: ref = harv (odkaz)
  • Tanenbaum, Andrew (2009). Moderní operační systémy, třetí vydání. 209–210
  • Denning, P.J. (1980). Pracovní nastavení minulosti a současnosti. Transakce IEEE na softwarovém inženýrství, 1/1980, svazek SE-6, str. 64–84. [1]
  • Silberschatz, A., Galvin, P. B. a Gagne, G. (2005). Koncepty operačního systému, 7. vydání. Palatino: Wiley. 346.