Thrashing (počítačová věda) - Thrashing (computer science)

v počítačová věda, mlácení nastane, když je počítač virtuální paměť zdroje jsou nadměrně využívány, což vede ke stálému stavu stránkování a chyby stránky, inhibuje většinu aplikace -úrovňové zpracování.[1] To způsobí výkon počítače degradovat nebo se zhroutit. Situace může pokračovat neomezeně dlouho, dokud uživatel nezavře některé spuštěné aplikace nebo dokud aktivní procesy neuvolní další prostředky virtuální paměti.


Po dokončení inicializace většina programů pracuje na malém počtu kódových a datových stránek ve srovnání s celkovou pamětí, kterou program vyžaduje. Nejčastěji navštěvované stránky se nazývají pracovní sada.

Když je pracovní sada malým procentem z celkového počtu stránek systému, systémy virtuální paměti fungují nejefektivněji a zanedbávání výpočetních prostředků se vynakládá na řešení chyb stránek. Jak pracovní sada roste, řešení poruch stránek zůstává zvládnutelné, dokud růst nedosáhne kritického bodu. Pak chyby dramaticky vzrostou a čas strávený jejich řešením přemůže čas strávený výpočtem programu, který byl napsán. Tato podmínka se označuje jako mlácení. K výprasku dochází v programu, který pracuje s obrovskými datovými strukturami, protože jeho velká pracovní sada způsobuje neustálé poruchy stránek, které drasticky zpomalují systém. Uspokojování poruch stránek může vyžadovat uvolnění stránek, které bude brzy nutné znovu načíst z disku.


Termín se také používá pro různé podobné jevy, zejména pohyb mezi ostatními úrovněmi EU hierarchie paměti, kde proces postupuje pomalu, protože značný čas se vynakládá na získávání zdrojů.

„Thrashing“ se používá také v jiných kontextech než systémy virtuální paměti; například popsat mezipaměti problémy s výpočetní technikou nebo syndrom hloupého okna v síti.

Přehled

Virtuální paměť funguje ošetřením části vedlejší sklad jako je pevný disk počítače jako další vrstva hierarchie mezipaměti. Virtuální paměť je pozoruhodná pro povolení procesy použít více paměti, než je fyzicky přítomno v hlavní paměť a za umožnění virtuální stroje. Operační systémy podporující procesy přiřazování virtuální paměti a virtuální adresový prostor a každý proces odkazuje adresy v jeho kontext provádění tzv. virtuální adresou. Za účelem přístupu data jako kód nebo proměnné na této adrese musí proces přeložit adresu na a fyzická adresa v procesu známém jako překlad virtuální adresy. Ve skutečnosti se fyzická hlavní paměť stává a mezipaměti pro virtuální paměť, která je obecně uložena na disku v systému Windows stránky paměti.

Programům je podle potřeby přidělen určitý počet stránek operační systém. Stránky aktivní paměti existují jak v paměti RAM, tak na disku. Neaktivní stránky jsou odstraněn z mezipaměti a zapsán na disk když se hlavní paměť zaplní.

Pokud procesy využívají veškerou hlavní paměť a potřebují další stránky paměti, kaskáda těžkých procesů chybí mezipaměť známý jako chyby stránky dojde, což často vede k znatelnému zpoždění v operačním systému citlivost. Tento proces spolu s zbytečným opakovaným zaměňováním stránek se označuje jako „výprask“. To často vede k vysokému využití uprchlého procesoru, které může systém zastavit. V moderních počítačích může dojít k výprasku ve stránkovacím systému (pokud to není dostatečné) fyzická paměť nebo je doba přístupu k disku příliš dlouhá), nebo v I / O komunikačním subsystému (zejména v konflikty kvůli internímu přístupu na sběrnici ), atd.

V závislosti na použité konfiguraci a použitých algoritmech propustnost a latence systému se může znehodnotit více řádově. Thrashing je stav, ve kterém CPU vykonává méně „produktivní“ práci a více „vyměňuje“. Celková doba přístupu do paměti se může prodloužit, protože paměť vyšší úrovně je pouze tak rychlá jako další nižší úroveň v hierarchii paměti.[2] CPU je zaneprázdněn výměnou stránek natolik, že nemůže reagovat na programy uživatelů a přerušuje tolik, kolik je potřeba. K mlácení dochází, když je v paměti příliš mnoho stránek a každá stránka odkazuje na jinou stránku. Skutečná paměť zkracuje kapacitu, aby do ní byly zahrnuty všechny stránky, takže využívá „virtuální paměť“. Když každá spuštěná stránka vyžaduje stránku, která není aktuálně ve skutečné paměti (RAM), umístí některé stránky do virtuální paměti a upraví požadovanou stránku v RAM. Pokud je CPU při provádění tohoto úkolu příliš zaneprázdněn, dojde k výprasku.

Příčiny

v virtuální paměť systémy, může být výprask způsoben programy nebo úlohami, které jsou nedostatečné referenční lokalita: pokud pracovní sada programu nebo pracovní zátěž nelze efektivně udržet ve fyzické paměti, pak neustálé střídání dat, tj., může dojít k výprasku. Termín byl poprvé použit během dnů páskového operačního systému k popisu zvuku, který vydávaly pásky při rychlém zápisu a čtení dat. Nejhorší scénář tohoto druhu na Systém IBM / 370 série sálový počítač může to být instrukce spuštění překračující hranici stránky, která ukazuje na samotnou instrukci přesunu, rovněž překračující hranici stránky, sama ukazuje na zdroj a cíl, který překračuje hranice každé stránky. Celkový počet stránek takto zapojených do této konkrétní instrukce je osm a všech osm stránek musí být současně přítomno v paměti. Pokud některá z osmi stránek nemůže být vyměnil (například aby se uvolnilo místo pro kteroukoli z dalších stránek), instrukce selže a každý pokus o její restart selže, dokud nebude možné vyměnit všech osm stránek.

Jiná použití

Thrashing je nejlépe známý v kontextu paměti a úložiště, ale analogické jevy se vyskytují iu jiných zdroje, počítaje v to:

Cache mlácení

Kde je k hlavní paměti přistupováno ve vzoru, který vede k tomu, že více hlavních paměťových míst soutěží o stejné řádky mezipaměti, což vede k nadměrnému chybí mezipaměť. To je nejproblematičtější pro mezipaměti, které mají nízké hodnoty asociativita.

Výprask TLB

Kde překlad lookaside buffer (TLB) fungující jako mezipaměť pro jednotka správy paměti (MMU), který převádí virtuální adresy na fyzické, je pro pracovní sadu stránek příliš malý. K mlácení TLB může dojít, i když nedochází k mlácení mezipaměti instrukcí nebo datové mezipaměti, protože jsou ukládány do mezipaměti v různých velikostech. Pokyny a data se ukládají do malých bloků (řá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 pracovní sady ano roztříštěný na mnoha stránkách se pracovní sada virtuální adresy nemusí vejít do TLB, což způsobí mlácení TLB.

Halda mlátila

Časté odvoz odpadu, kvůli selhání alokace paměti pro objekt, kvůli nedostatečné volné paměti nebo nedostatečné souvislé volné paměti kvůli fragmentace paměti je označováno jako hromadné mlácení.[3]

Proces mlácení

Podobný jev nastává u procesů: když procesní pracovní sada nemůže být naplánováno - takže ne všechny interagující procesy jsou naplánovány tak, aby běžely současně - dochází k „výprasku procesu“ kvůli opakovanému naplánování a neplánování, postupují jen pomalu.[4]

Viz také

Reference

  1. ^ Denning, Peter J. (1968). „Thrashing: jeho příčiny a prevence“ (PDF). Proceedings AFIPS, Fall Joint Computer Conference. 33: 915–922. Citováno 2012-02-15.
  2. ^ L., Hennessy, John (2012). Počítačová architektura: kvantitativní přístup. Patterson, David A., Asanović, Krste. (5. vydání). Waltham, MA: Morgan Kaufmann. ISBN  9780123838728. OCLC  755102367.
  3. ^ Techniky optimalizace výkonu a ladění pro procesory IBM, včetně IBM POWER8, „halda + výprask“ str. 170
  4. ^ 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. s. 22–30.CS1 maint: ref = harv (odkaz)