Dvoufázové zamykání - Two-phase locking
v databáze a zpracování transakcí, dvoufázové zamykání (2PL) je řízení souběžnosti metoda, která zaručuje serializovatelnost.[1][2]Je to také název výsledné sady transakce databáze plány (historie). Protokol využívá zámky, aplikovaná transakcí na data, která mohou blokovat (interpretovat jako signály k zastavení) jiných transakcí v přístupu ke stejným datům během doby trvání transakce.
Protokolem 2PL se zámky aplikují a odstraňují ve dvou fázích:
- Fáze rozšiřování: zámky se získají a žádné zámky se neuvolní.
- Fáze smršťování: zámky jsou uvolněny a nejsou získány žádné zámky.
Základní protokol využívá dva typy zámků: Sdílené a Výhradní zámky. Upřesnění základního protokolu mohou využívat více typů zámku. Při použití zámků, které blokují procesy, může 2PL podléhat zablokování které vyplývají ze vzájemného blokování dvou nebo více transakcí.
Zámky pro přístup k datům
A zámek je systémový objekt přidružený ke sdílenému prostředku, jako je datová položka elementárního typu, řádek v databázi nebo stránka paměti. V databázi může být nutné získat přístup k objektu databáze (zámek přístupu k datům) transakcí před přístupem k objektu. Správné použití zámků zabrání nežádoucím, nesprávným nebo nekonzistentním operacím se sdílenými prostředky jinými souběžnými transakcemi. Když je třeba k databázovému objektu s existujícím zámkem získaným jednou transakcí získat přístup jinou transakcí, systém zkontroluje existující zámek objektu a typ zamýšleného přístupu. Pokud stávající typ zámku neumožňuje tento konkrétní typ souběžného přístupu, pokus o přístup je blokován (podle předem definované dohody / schématu). V praxi zámek na objektu neblokuje přímo operaci transakce na objektu, ale spíše blokuje tuto transakci v získání dalšího zámku na stejném objektu, který musí být transakcí držen / vlastněn před provedením této operace. U uzamykacího mechanismu je tedy potřebné blokování provozu řízeno řádným blokovacím schématem zámku, které označuje, který typ zámku blokuje, který typ zámku.
Používají se dva hlavní typy zámků:
- Zámek proti zápisu (exkluzivní zámek) je spojen s databázovým objektem transakcí (Terminologie: „transakce uzamkne objekt“ nebo „získá zámek pro něj“) před psaní (vložení / úprava / odstranění) tohoto objektu.
- Zámek proti čtení (sdílený zámek) je spojen s databázovým objektem transakcí dříve čtení (načítání stavu) tohoto objektu.
Běžné interakce mezi těmito typy zámku jsou definovány blokovacím chováním takto:
- Existující zámek zápisu na databázovém objektu blokuje zamýšlený psát si na stejný objekt (již požadovaný / vydaný) jinou transakcí blokováním příslušného zámek zápisu od získání jinou transakcí. Po uvolnění stávajícího zámku pro zápis bude získán druhý zámek pro zápis a požadovaný zápis objektu proběhne (zhmotní se).
- A zámek zápisu blokuje zamýšlený (již požadovaný / vydaný) číst jinou transakcí blokováním příslušných zámek čtení .
- A zámek čtení blokuje zamýšlený psát si jinou transakcí blokováním příslušných zámek zápisu.
- A zámek čtení neblokuje zamýšlený číst jinou transakcí. Příslušné zámek čtení pro zamýšlené čtení je získáno (sdíleno s předchozím čtením) bezprostředně poté, co je požadováno zamýšlené čtení, a poté proběhne samotné zamýšlené čtení.
Existuje několik variací a vylepšení těchto hlavních typů zámku s příslušnými variacemi chování blokování. Pokud první zámek blokuje další zámek, jsou vyvolány dva zámky nekompatibilní; jinak jsou zámky kompatibilní. Interakce blokující typy zámku jsou v technické literatuře často prezentovány a Tabulka kompatibility zámku. Následuje příklad běžných hlavních typů zámku:
Tabulka kompatibility zámku Typ zámku zámek čtení zámek zápisu zámek čtení X zámek zápisu X X
- X označuje nekompatibilitu, tj. případ, kdy zámek prvního typu (v levém sloupci) na objektu blokuje získání zámku druhého typu (v horním řádku) na stejném objektu (jinou transakcí). Objekt má obvykle frontu čekajících operací (transakcí) s příslušnými zámky. První blokovaný zámek pro provoz ve frontě je získán, jakmile je stávající blokující zámek odstraněn z objektu, a poté je provedena jeho příslušná operace. Pokud zámek pro provoz ve frontě není blokován žádným existujícím zámkem (existence více kompatibilních zámků na stejném objektu je možná současně), je získán okamžitě.
- Komentář: V některých publikacích jsou položky tabulky jednoduše označeny jako „kompatibilní“ nebo „nekompatibilní“, respektive „ano“ nebo „ne“.
Dvoufázové zamykání a jeho speciální případy
Dvoufázové zamykání
Podle dvoufázové zamykání protokol, transakce zpracovává své zámky ve dvou odlišných po sobě následujících fázích během provádění transakce:
- Rozšiřující se fáze (aka Fáze růstu): zámky se získají a žádné zámky se neuvolní (počet zámků se může pouze zvýšit).
- Fáze smršťování (aka fáze smluvní): zámky jsou uvolněny a žádné zámky nejsou získány.
Pravidla dvoufázového zamykání lze shrnout jako: nikdy nezískejte zámek po uvolnění zámku. The serializovatelnost vlastnost je zaručena pro plán s transakcemi, které se řídí tímto pravidlem.
Typicky, bez explicitní znalosti transakce na konci fáze 1, je bezpečně určena pouze v případě, že transakce dokončila zpracování a požadovala potvrzení. V takovém případě lze všechny zámky odblokovat najednou (fáze 2).
Konzervativní dvoufázové blokování
Rozdíl mezi 2PL a C2PL je to, že transakce C2PL získají všechny zámky, které potřebují, než transakce začnou. Tím je zajištěno, že transakce, která již obsahuje některé zámky, nebude blokovat čekání na další zámky. Konzervativní 2PL brání zablokování.
Přísné dvoufázové blokování
Aby bylo možné vyhovět protokolu S2PL, musí transakce vyhovovat 2PL a uvolnit jej napsat (exkluzivně) zamkne až poté, co skončí, tj. buď angažovaný nebo přerušena. Na druhou stranu, číst (sdílené) zámky jsou pravidelně uvolňovány během fáze 2. Tento protokol není vhodný pro B-stromy, protože způsobuje úzké místo (zatímco B-stromy vždy začínají hledat z nadřazeného kořene).[Citace je zapotřebí ]
Silné přísné dvoufázové blokování
nebo Důslednostnebo Přísné plánovánínebo Přísné dvoufázové blokování
V souladu s silné přísné dvoufázové blokování (SS2PL) uzamykací protokol uvolňuje obojí napsat (exkluzivně) a číst (sdílené) zámky aplikované transakcí až po ukončení transakce, tj. až po obou dokončení provádění (bytí připraven) a stát se buď angažovaný nebo přerušena. Tento protokol také vyhovuje pravidlům S2PL. Transakci, která se řídí SS2PL, lze považovat za transakci, která má fázi 1, která trvá celou dobu provádění transakce, a žádnou fázi 2 (nebo degenerovanou fázi 2). Ve skutečnosti tedy zbývá pouze jedna fáze a zdá se, že „dvoufázová“ v názvu je stále využívána kvůli historickému vývoji konceptu z 2PL a 2PL je nadtřída. Vlastnost SS2PL plánu se také nazývá Důslednost. Je to také název třídy plánů, které mají tuto vlastnost, a plán SS2PL se také nazývá „přísný plán“. Pojem „přísnost“ neobsahuje zbytečné dědictví „dvoufázového“ a nezávisí na žádném (zajišťovacím) mechanismu (v zásadě lze použít jiné blokovací mechanismy). Příslušný uzamykací mechanismus nemovitosti se někdy označuje jako Rigorózní 2PL.
SS2PL je speciální případ S2PL, tj. Třída plánů SS2PL je správná podtřída S2PL (každý plán SS2PL je také plánem S2PL, ale existují plány S2PL, které nejsou SS2PL).
SS2PL je protokol řízení souběžnosti, který si většina vybrala databázové systémy a využívány od jejich počátků v 70. letech. Ukázalo se, že je účinným mechanismem v mnoha situacích, a kromě toho poskytuje Serializovatelnost taky Přísnost (speciální případ obnovitelnosti bez kaskády), který je efektivní pro efektivní databáze zotavení, a také Objednávka závazku (CO) pro účast v distribuovaných prostředích, kde je založen CO distribuovaná serializovatelnost a globální serializovatelnost jsou použita řešení. Být podmnožinou CO, efektivní implementace distribuovaný SS2PL existuje bez a správce distribuovaného zámku (DLM), zatímco distribuované zablokování (viz níže) se vyřeší automaticky. Skutečnost, že SS2PL používaný v multi databázových systémech zajišťuje globální serializovatelnost, je známa již roky před objevením CO, ale pouze s CO přišlo pochopení role atomový závazek protokol při udržování globální serializovatelnosti, stejně jako sledování automatického distribuovaného rozlišení zablokování (viz podrobný příklad distribuovaného SS2PL ). Ve skutečnosti je SS2PL zděděné vlastnosti Recoverability a CO významnější než podmnožina 2PL, která sama o sobě ve své obecné podobě kromě toho obsahuje jednoduchý mechanismus serializovatelnosti (nicméně serializovatelnost je implicitně obsažena také v CO), není známo poskytovat SS2PL jakékoli další významné vlastnosti. 2PL v jeho obecné podobě, stejně jako v kombinaci s Strictness, tj. Strict 2PL (S2PL), není známo, že se v praxi používá. Populární SS2PL nevyžaduje označení „konec fáze 1“ jako 2PL a S2PL, a proto je jeho implementace jednodušší. Na rozdíl od obecného 2PL také SS2PL poskytuje, jak je uvedeno výše, užitečné Přísnost a Objednávka závazku vlastnosti.
Existuje mnoho variant SS2PL, které využívají různé typy zámku s různou sémantikou v různých situacích, včetně případů změny typu zámku během transakce. Pozoruhodné jsou varianty, které používají Vícenásobné uzamčení podrobností.
Komentáře:
- SS2PL vs. S2PL: Oba poskytují serializovatelnost a přísnost. Protože S2PL je nadtřída SS2PL, může v zásadě poskytovat více souběžnosti. Obvykle si však prakticky nevšimnete žádné výhody souběžnosti (pro oba existuje přesně stejné zamykání, s prakticky ne mnohem dřívějším uvolněním zámku pro S2PL) a režie řešení mechanismu konce fáze 1 v S2PL, odděleně od konce transakce , není oprávněná. I když SS2PL poskytuje Objednávka závazku, S2PL ne. To vysvětluje preference SS2PL před S2PL.
- Zejména před rokem 1990, ale také po něm, v mnoha článcích a knihách, např. (Bernstein et al. 1987, s. 59),[1] termín „Strict 2PL“ (S2PL) byl často definován uzamykacím protokolem „Release all locks only after operation end,“ což je protokol SS2PL. Proto „Strict 2PL“ nemohl být název křižovatky Strictness a 2PL, který je větší než třída generovaná protokolem SS2PL. To způsobilo zmatek. S explicitní definicí S2PL jako průsečíku Strictness a 2PL, novým názvem pro SS2PL a výslovným rozlišením mezi třídami S2PL a SS2PL, články (Breitbart et al. 1991)[3] a (Raz 1992)[4] mají v úmyslu očistit zmatek: první používá název „přísnost“ a druhý „SS2PL“.
- Existuje obecnější vlastnost než SS2PL (nadřazená třída plánu), Přísné objednávání závazků (Strict CO nebo SCO), který také poskytuje jak serializovatelnost, přísnost, tak CO a má podobnou režii uzamčení. Na rozdíl od SS2PL SCO neblokuje při konfliktu čtení a zápisu (zámek čtení neblokuje získání zámku zápisu; SCO i SS2PL mají stejné chování pro konflikty zápisu a čtení i zápisu a zápisu) za cenu možného zpoždění spáchat a při takovém konfliktu má SCO kratší průměrnou dobu dokončení transakce a lepší výkon než SS2PL.[5] Zatímco SS2PL se řídí tabulka kompatibility zámku výše má SCO následující tabulku:
Kompatibilita zámku pro SCO Typ zámku zámek čtení zámek zápisu zámek čtení zámek zápisu X X
- Všimněte si, že ačkoli SCO uvolní všechny zámky na konci transakce a splňuje pravidla zamykání 2PL, SCO není podmnožinou 2PL kvůli své jiné tabulce kompatibility zámku. SCO umožňuje materializované konflikty čtení a zápisu mezi dvěma transakcemi v jejich fázích 1, což 2PL neumožňuje ve fázi 1 (viz materializované konflikty v Serializovatelnost ). Na druhou stranu 2PL umožňuje další materializované typy konfliktů ve fázi 2, které SCO vůbec neumožňuje. Společně to znamená, že třídy plánu 2PL a SCO jsou nesrovnatelné (tj. Žádná třída neobsahuje druhou třídu).
Shrnutí - Vztahy mezi třídami
Mezi libovolnými dvěma třídami plánu (definovanými příslušnými vlastnostmi jejich plánů), které mají společné plány, buď jednu obsahuje jiný (přísně obsahuje pokud nejsou stejné), nebo jsou nesrovnatelný. Vztahy omezení mezi třídami 2PL a dalšími hlavními třídami harmonogramu jsou shrnuty v následujícím diagramu. 2PL a jeho podtřídy jsou neodmyslitelně blokující, což znamená, že pro ně neexistují žádné optimistické implementace (a kdykoli je uvedeno „Optimistické 2PL“, odkazuje na jiný mechanismus s třídou, která zahrnuje i plány, které nejsou ve třídě 2PL).
Zablokování v 2PL
Zámky blokují operace přístupu k datům. Výsledkem vzájemného blokování mezi transakcemi je a zablokování, kde je provádění těchto transakcí pozastaveno a nelze dosáhnout žádného dokončení. Je tedy třeba vyřešit zablokování, aby bylo možné dokončit provádění těchto transakcí a uvolnit výpočetní zdroje související. Zablokování je odrazem potenciálního cyklu v prioritní graf, k němuž by došlo bez blokování. Zablokování je vyřešeno přerušením transakce spojené s takovým potenciálním cyklem a přerušením cyklu. Často se detekuje pomocí a čekat na graf (graf konfliktů blokovaných zámky před uskutečněním; konflikty, které se v databázi neuskutečnily kvůli zablokovaným operacím, se v grafu priority neprojeví a neovlivní serializovatelnost ), který označuje, která transakce „čeká na“ uvolnění zámku, u které transakce, a cyklus znamená zablokování. K přerušení cyklu stačí přerušení jedné transakce za cyklus. Pokud byla transakce přerušena z důvodu zablokování, je na aplikaci, aby se rozhodla, co dělat dál. Aplikace obvykle restartuje transakci od začátku, ale může tuto akci odložit, aby poskytla ostatním transakcím dostatek času na dokončení, aby se zabránilo dalšímu zablokování.[6]
V distribuovaném prostředí atomový závazek protokol, obvykle Dvoufázové potvrzení (2PC) protokol, se používá pro atomicita. Když jsou obnovitelná data (data pod kontrolou transakcí) rozdělena mezi účastníky 2PC (tj. Každý datový objekt je řízen jedním účastníkem 2PC), pak distribuovaná (globální) zablokování, zablokování zahrnující dva nebo více účastníků ve 2PC, jsou automaticky vyřešena takto:
Když je SS2PL efektivně využíván v distribuovaném prostředí, pak globální zablokování v důsledku uzamčení generují zablokování hlasování ve 2PC a jsou automaticky vyřešena 2PC (viz Objednávka závazku (CO), v Přesná charakteristika zablokování hlasování globálními cykly; Není známo, že by si toho všiml žádný odkaz kromě článků o CO). Pro obecný případ 2PL jsou globální zablokování podobně automaticky vyřešena synchronizační bod protokol konce fáze 1 v distribuované transakci (bodu synchronizace se dosáhne „hlasováním“ (oznámení místního konce fáze 1) a je propagován účastníkům distribuované transakce stejným způsobem jako rozhodovací bod v atomovém závazku; v analogie k rozhodovacímu bodu v CO, ke konfliktní operaci v 2PL nemůže dojít před koncovým bodem synchronizace fáze 1, se stejným výsledným zablokováním hlasování v případě globálního zablokování přístupu k datům; hlasovací zablokování (což je také zamykání založené na globálním zablokování) je automaticky vyřešen protokolem, který přeruší příslušnou transakci s chybějícím hlasem, obvykle pomocí a Časový limit ).
Komentář:
- Když jsou data rozdělena mezi atomový závazek protokol (např. 2PC) účastníci, automaticky globální zablokování rozlišení bylo v literatuře o databázovém výzkumu přehlíženo, ačkoli uváznutí v těchto systémech bylo poměrně intenzivní oblastí výzkumu:
- U CO a jeho zvláštního případu SS2PL je automatické rozlišení pomocí atomový závazkový protokol byl zaznamenán pouze v článcích CO. V praxi však bylo zjištěno, že v mnoha případech jsou globální zablokování velmi zřídka detekována vyhrazenými mechanismy řešení, méně než by se dalo očekávat („Proč vidíme tak málo globálních zablokování?“). Důvodem jsou pravděpodobně zablokování, která jsou automaticky vyřešena, a proto je mechanismy nezpracovávají a nepočítají;
- U 2PL obecně je automatické rozlišení (povinné) protokol synchronizačního bodu na konci fáze jedna (který má stejný hlasovací mechanismus jako protokol atomových závazků a stejné zpracování chybějících hlasů při zablokování hlasování, což má za následek globální řešení zablokování), o nichž se dnes (2009) nezmínilo. Prakticky se používá pouze speciální případ SS2PL, kde kromě protokolu atomic commit není potřeba žádná synchronizace na konci fáze jedna.
- V distribuovaném prostředí, kde obnovitelná data nejsou rozdělena mezi účastníky protokolu atomového závazku, takové automatické rozlišení neexistuje a distribuované zablokování je třeba vyřešit specializovanými technikami.
Viz také
Reference
- ^ A b Philip A. Bernstein, Vassos Hadzilacos, Nathan Goodman (1987): Řízení a obnova souběžnosti v databázových systémech, Addison Wesley Publishing Company, ISBN 0-201-10715-5
- ^ Gerhard Weikum Gottfried Vossen (2001): Transakční informační systémy, Elsevier, ISBN 1-55860-508-8
- ^ Yuri Breitbart, Dimitrios Georgakopoulos, Marek Rusinkiewicz, Abraham Silberschatz (1991): „Rigorous Transaction Scheduling“, Transakce IEEE v softwarovém inženýrství (TSE), září 1991, svazek 17, vydání 9, str. 954-960, ISSN 0098-5589
- ^ Yoav Raz (1992): „Princip objednávání závazků nebo zaručení serializovatelnosti v heterogenním prostředí více správců autonomních zdrojů využívajících atomový závazek“ Archivováno 2007-05-23 na Wayback Machine (PDF ), Sborník příspěvků z osmnácté mezinárodní konference o velmi velkých databázích (VLDB), s. 292-312, Vancouver, Kanada, srpen 1992, ISBN 1-55860-151-1 (také DEC-TR 841, Digital Equipment Corporation, Listopad 1990)
- ^ Yoav Raz (1991): „Locking Based Strict Commitment Ordering, or How to improve Concurrency in Locking Based Resource Managers“, DEC-TR 844, prosinec 1991.
- ^ Zásady zpracování transakcí; ISBN 9780080948416; Kapitola 6 Strana 152