Rozproszony DBMS - Obsługa zakleszczeń
W tym rozdziale omówiono mechanizmy obsługi zakleszczeń w systemach baz danych. Przeanalizujemy mechanizmy obsługi zakleszczeń zarówno w scentralizowanym, jak i rozproszonym systemie baz danych.
Co to są zakleszczenia?
Zakleszczenie to stan systemu bazy danych, w którym występują dwie lub więcej transakcji, kiedy każda transakcja oczekuje na element danych, który jest blokowany przez inną transakcję. Zakleszczenie może być wskazywane przez cykl na wykresie oczekiwania na. Jest to wykres skierowany, w którym wierzchołki oznaczają transakcje, a krawędzie oznaczają oczekiwania na elementy danych.
Na przykład w poniższym grafie oczekiwania na transakcję T1 oczekuje element danych X, który jest zablokowany przez T3. T3 czeka na Y, które jest zablokowane przez T2, a T2 czeka na Z, które jest blokowane przez T1. W związku z tym powstaje cykl oczekiwania i żadna z transakcji nie może kontynuować wykonywania.
Obsługa zakleszczenia w systemach scentralizowanych
Istnieją trzy klasyczne podejścia do obsługi impasu, a mianowicie:
- Zapobieganie zakleszczeniom.
- Unikanie impasu.
- Wykrywanie i usuwanie zakleszczeń.
Wszystkie trzy podejścia można zastosować zarówno w scentralizowanym, jak i rozproszonym systemie baz danych.
Zapobieganie zakleszczeniom
Podejście zapobiegające zakleszczeniom nie pozwala żadnej transakcji na uzyskanie blokad, które doprowadzą do zakleszczenia. Konwencja jest taka, że gdy więcej niż jedna transakcja żąda zablokowania tego samego elementu danych, tylko jedna z nich jest blokowana.
Jedną z najpopularniejszych metod zapobiegania zakleszczeniom jest wstępne przejęcie wszystkich blokad. W tej metodzie transakcja nabywa wszystkie blokady przed rozpoczęciem wykonywania i zachowuje blokady przez cały czas trwania transakcji. Jeśli inna transakcja wymaga któregokolwiek z już nabytych blokad, musi poczekać, aż wszystkie potrzebne blokady będą dostępne. Stosując to podejście, zapobiega się zakleszczeniu systemu, ponieważ żadna z oczekujących transakcji nie posiada żadnej blokady.
Unikanie impasu
Podejście unikania zakleszczeń obsługuje zakleszczenia, zanim one wystąpią. Analizuje transakcje i blokady, aby określić, czy oczekiwanie prowadzi do impasu.
Metodę można pokrótce opisać w następujący sposób. Transakcje rozpoczynają się i żądają elementów danych, które muszą zablokować. Menedżer blokad sprawdza, czy blokada jest dostępna. Jeśli jest dostępny, menedżer blokad przydziela element danych, a transakcja uzyskuje blokadę. Jeśli jednak pozycja jest zablokowana przez inną transakcję w trybie niezgodnym, menedżer blokady uruchamia algorytm w celu sprawdzenia, czy utrzymywanie transakcji w stanie oczekiwania spowoduje zakleszczenie, czy nie. W związku z tym algorytm decyduje, czy transakcja może czekać, czy też jedna z transakcji powinna zostać przerwana.
Do tego celu służą dwa algorytmy wait-die i wound-wait. Załóżmy, że istnieją dwie transakcje, T1 i T2, w których T1 próbuje zablokować pozycję danych, która jest już zablokowana przez T2. Algorytmy są następujące -
Wait-Die- Jeśli T1 jest starszy niż T2, T1 może czekać. W przeciwnym razie, jeśli T1 jest młodszy niż T2, T1 jest przerywany i później uruchamiany ponownie.
Wound-Wait- Jeśli T1 jest starszy niż T2, T2 jest przerywany i później uruchamiany ponownie. W przeciwnym razie, jeśli T1 jest młodszy niż T2, T1 może czekać.
Wykrywanie i usuwanie zakleszczeń
Podejście do wykrywania i usuwania zakleszczeń okresowo uruchamia algorytm wykrywania zakleszczeń i usuwa zakleszczenia w przypadku ich wystąpienia. Nie sprawdza zakleszczenia, gdy transakcja zgłasza żądanie blokady. Kiedy transakcja żąda blokady, menedżer blokady sprawdza, czy jest ona dostępna. Jeśli jest dostępny, transakcja może zablokować element danych; w przeciwnym razie transakcja może czekać.
Ponieważ nie ma żadnych środków ostrożności podczas przyznawania żądań blokady, niektóre transakcje mogą być zakleszczone. Aby wykryć zakleszczenia, menedżer blokad okresowo sprawdza, czy wykres oczekiwania ma cykle. Jeśli system jest zakleszczony, menedżer blokad wybiera transakcję ofiary z każdego cyklu. Ofiara zostaje przerwana i cofnięta; a następnie uruchomiono ponownie później. Niektóre z metod stosowanych do selekcji ofiar to:
- Wybierz najmłodszą transakcję.
- Wybierz transakcję z najmniejszą liczbą pozycji danych.
- Wybierz transakcję, która wykonała najmniejszą liczbę aktualizacji.
- Wybierz transakcję, która ma najmniejszy koszt ponownego uruchomienia.
- Wybierz transakcję, która jest wspólna dla dwóch lub więcej cykli.
To podejście jest przede wszystkim odpowiednie dla systemów z niską liczbą transakcji i gdzie potrzebna jest szybka odpowiedź na żądania blokad.
Obsługa zakleszczenia w systemach rozproszonych
Przetwarzanie transakcji w rozproszonym systemie baz danych jest również rozproszone, tj. Ta sama transakcja może być przetwarzana w więcej niż jednym miejscu. Dwa główne problemy związane z obsługą zakleszczeń w rozproszonym systemie baz danych, które nie występują w systemie scentralizowanym, totransaction location i transaction control. Po rozwiązaniu tych problemów zakleszczenia są obsługiwane za pomocą dowolnej metody zapobiegania zakleszczeniom, unikania zakleszczeń lub wykrywania i usuwania zakleszczeń.
Lokalizacja transakcji
Transakcje w systemie rozproszonej bazy danych są przetwarzane w wielu witrynach i wykorzystują elementy danych w wielu witrynach. Ilość przetwarzanych danych nie jest równomiernie rozłożona na te witryny. Różny jest również okres przetwarzania. Zatem ta sama transakcja może być aktywna w niektórych witrynach, a nieaktywna w innych. Gdy w witrynie znajdują się dwie sprzeczne transakcje, może się zdarzyć, że jedna z nich jest nieaktywna. Ten stan nie występuje w systemie scentralizowanym. Ten problem nazywa się problemem lokalizacji transakcji.
Ten problem może rozwiązać model Daisy Chain. W tym modelu transakcja zawiera pewne szczegóły podczas przenoszenia z jednej witryny do drugiej. Niektóre szczegóły to lista wymaganych tabel, lista wymaganych witryn, lista odwiedzonych tabel i witryn, lista tabel i witryn, które jeszcze nie zostały odwiedzone oraz lista nabytych blokad z typami. Po zakończeniu transakcji przez zatwierdzenie lub przerwanie, informacje powinny zostać wysłane do wszystkich zainteresowanych stron.
Kontrola transakcji
Kontrola transakcji dotyczy wyznaczania i kontrolowania miejsc wymaganych do przetwarzania transakcji w systemie rozproszonej bazy danych. Istnieje wiele opcji dotyczących wyboru miejsca przetwarzania transakcji i wyznaczania centrum kontroli, na przykład -
- Jeden serwer może zostać wybrany jako centrum kontroli.
- Centrum kontroli może przemieszczać się z jednego serwera na drugi.
- Odpowiedzialność za kontrolowanie może być współdzielona przez kilka serwerów.
Rozproszone zapobieganie zakleszczeniom
Podobnie jak w przypadku scentralizowanego zapobiegania zakleszczeniom, w rozproszonym podejściu do zapobiegania zakleszczeniom transakcja powinna uzyskać wszystkie blokady przed rozpoczęciem wykonywania. Zapobiega to zakleszczeniom.
Witryna, do której dochodzi transakcja, jest wyznaczana jako witryna kontrolna. Witryna kontrolująca wysyła komunikaty do witryn, w których znajdują się elementy danych, w celu ich zablokowania. Następnie czeka na potwierdzenie. Gdy wszystkie strony potwierdzą, że zablokowały pozycje danych, rozpoczyna się transakcja. Jeśli jakakolwiek witryna lub łącze komunikacyjne ulegnie awarii, transakcja musi poczekać, aż zostaną naprawione.
Chociaż implementacja jest prosta, to podejście ma pewne wady -
Wstępne przejęcie blokad wymaga długiego czasu na opóźnienia w komunikacji. Zwiększa to czas potrzebny na transakcję.
W przypadku awarii witryny lub łącza transakcja musi długo czekać, aby witryny zostały przywrócone. Tymczasem w uruchomionych witrynach pozycje są zablokowane. Może to uniemożliwić wykonanie innych transakcji.
Jeśli witryna kontrolująca zawiedzie, nie może komunikować się z innymi lokacjami. Witryny te nadal utrzymują zablokowane elementy danych w stanie zablokowanym, co powoduje blokowanie.
Rozproszone unikanie zakleszczenia
Podobnie jak w systemie scentralizowanym, rozproszone unikanie zakleszczenia obsługuje zakleszczenie przed jego wystąpieniem. Ponadto w systemach rozproszonych należy zająć się kwestiami lokalizacji i kontroli transakcji. Ze względu na rozproszony charakter transakcji mogą wystąpić następujące konflikty -
- Konflikt między dwiema transakcjami w tej samej witrynie.
- Konflikt między dwiema transakcjami w różnych witrynach.
W przypadku konfliktu jedna z transakcji może zostać przerwana lub pozwolić na czekanie zgodnie z algorytmami rozproszonego czekania lub rozproszonego czekania na ranę.
Załóżmy, że istnieją dwie transakcje, T1 i T2. T1 dociera do Ośrodka P i próbuje zablokować element danych, który jest już zablokowany przez T2 w tym miejscu. W związku z tym istnieje konflikt w Ośrodku P. Algorytmy są następujące -
Distributed Wound-Die
Jeśli T1 jest starszy niż T2, T1 może czekać. T1 może wznowić wykonywanie po tym, jak ośrodek P otrzyma komunikat, że T2 zatwierdził lub przerwał pomyślnie we wszystkich lokalizacjach.
Jeśli T1 jest młodszy niż T2, T1 jest przerywany. Kontrola współbieżności w lokacji P wysyła komunikat do wszystkich lokacji, w których odwiedził T1, aby przerwać T1. Witryna kontrolująca powiadamia użytkownika o pomyślnym przerwaniu T1 we wszystkich witrynach.
Distributed Wait-Wait
Jeśli T1 jest starszy niż T2, T2 musi zostać przerwane. Jeżeli T2 jest aktywny w Ośrodku P, Ośrodek P przerywa i wycofuje T2, a następnie rozgłasza ten komunikat do innych odpowiednich miejsc. Jeżeli T2 opuścił ośrodek P, ale jest aktywny w ośrodku Q, ośrodek P rozgłasza, że T2 został przerwany; Ośrodek L następnie przerywa i wycofuje T2 i wysyła ten komunikat do wszystkich lokalizacji.
Jeśli T1 jest młodszy niż T1, T1 może czekać. T1 może wznowić wykonywanie po tym, jak ośrodek P otrzyma komunikat, że T2 zakończył przetwarzanie.
Rozproszone wykrywanie zakleszczeń
Podobnie jak podejście do scentralizowanego wykrywania zakleszczeń, zakleszczenia mogą wystąpić i są usuwane w przypadku wykrycia. System nie przeprowadza żadnych kontroli, gdy transakcja składa żądanie blokady. W celu wdrożenia tworzone są globalne wykresy oczekiwania na. Istnienie cyklu na globalnym wykresie oczekiwania na oznacza zakleszczenie. Jednak trudno jest wykryć zakleszczenia, ponieważ transakcja oczekuje na zasoby w sieci.
Alternatywnie algorytmy wykrywania zakleszczenia mogą wykorzystywać zegary. Każda transakcja jest powiązana z licznikiem czasu, który jest ustawiony na okres czasu, w którym transakcja ma się zakończyć. Jeśli transakcja nie zakończy się w tym czasie, licznik czasu wyłączy się, wskazując na możliwy zakleszczenie.
Innym narzędziem używanym do obsługi zakleszczenia jest detektor zakleszczenia. W systemie scentralizowanym istnieje jeden czujnik zakleszczenia. W systemie rozproszonym może istnieć więcej niż jeden detektor zakleszczenia. Detektor zakleszczenia może znaleźć zakleszczenia w kontrolowanych przez siebie miejscach. Istnieją trzy alternatywy dla wykrywania zakleszczeń w systemie rozproszonym, a mianowicie.
Centralized Deadlock Detector - Jedno miejsce jest wyznaczone jako centralny detektor zakleszczenia.
Hierarchical Deadlock Detector - Wiele detektorów zakleszczenia jest ułożonych hierarchicznie.
Distributed Deadlock Detector - Wszystkie witryny uczestniczą w wykrywaniu zakleszczeń i ich usuwaniu.