1 Fehlerbehandlung (Recovery) 1.Lokaler Fehler in einer noch nicht festgeschriebenen (committed) Transaktion Wirkung muss zurückgesetzt werden R1-Recovery.

Slides:



Advertisements
Ähnliche Präsentationen
Kapitel 15 Verteilte Datenbanken
Advertisements

Fast Fourier Transformation
Kap. 13 Sweep-Line Algorithmen Kap Schnittprobleme
Transaktionsverwaltung Beispiel einer typischen Transaktion in einer Bankanwendung: 1.Lese den Kontostand von A in die Variable a: read(A,a); 2.Reduziere.
Transaktionsverwaltung
© A. Kemper / A. Eickler1 Fehlerbehandlung (Recovery) 1.Lokaler Fehler in einer noch nicht festgeschriebenen (committed) Transaktion Wirkung muss zurückgesetzt.
1 Fehlerbehandlung (Recovery) 1.Lokaler Fehler in einer noch nicht festgeschriebenen (committed) Transaktion Wirkung muss zurückgesetzt werden R1-Recovery.
Transaktionsverwaltung Beispiel einer typischen Transaktion in einer Bankanwendung: 1.Lese den Kontostand von A in die Variable a: read(A,a); 2.Reduziere.
Anfrage-Optimierung und -Bearbeitung in Verteilten DBMS
Vorlesung Informatik 2 Algorithmen und Datenstrukturen (27 – Kürzeste Wege) Prof. Th. Ottmann.
Gottfried Vossen 5. Auflage 2008 Datenmodelle, Datenbanksprachen und Datenbankmanagementsysteme Kapitel 22: Grundlagen der Crash Recovery.
Transaktionen in verteilten Datenbanken
Prof. Dr. T. Kudraß1 Recovery. Prof. Dr. T. Kudraß2 Fehlerarten: Transaktionsfehler Transaktionsfehler –Freiwilliger Transaktionsfehler durch eine ROLLBACK-Anweisung.
AC Analyse.
Datenbanksysteme für FÜ SS 2000 Seite Worzyk FH Anhalt Transaktionen und Parallelverarbeitung Eigenschaften von Transaktionen Konsistenz Isolation.
Inhalte und Maßnahmen eingegeben haben,
Kapitel 13: Mehrbenutzersynchronisation
Kapitel 14: Recovery Oliver Vornberger
1 Kapitel 12: Transaktionsverwaltung Oliver Vornberger Fachbereich Mathematik/Informatik Universität Osnabrück Osnabrück
1 Kapitel 12: Transaktionsverwaltung. 2 Transaktion Bündelung mehrerer Datenbankoperationen Mehrbenutzersynchronisation Recovery.
Universität Karlsruhe (TH) © 2008 Univ,Karlsruhe, IPD, Prof. LockemannDBI 7 Kapitel 7 Zugriffsschicht: Zuverlässigkeit.
Recovery AIFB SS Recovery 5.1 Fehler im Datenbankbetrieb(1/10) (1)Transaktionsfehler (TF) (2)Systemfehler (SF) (3)Speicherfehler (SpF) Fehlerfallen.
ausdrucksschwächeres
Recovery AIFB SS Einbringstrategie der Pufferverwaltung(1/4) Die bestimmt, wann geänderte Seiten in die Datenbank eingebracht werden. Sie.
Recovery AIFB SS (1/8) Sicherungspunkte (Checkpoints) (1/8) (1) Transaktions-Orientierte Sicherungspunkte Transaction-Oriented Checkpoint.
Ausführungsmodell Zustandsübergang einer Transaktion aus Nutzersicht:
Implementierung von S2PL (1) Scheduler als Verwalter von Sperren auf Datenelementen sowie Warteschlangen für Sperren (Sperren-Verwalter). Transaktion 1Transaktion.
Modellierung von Transaktionen Zur Formalisierung der ACID-Garantien muss Verhalten von Transaktionen modelliert werden. Folge aus der Forderung nach lokaler.
Synchronisation paralleler Transaktionen AIFB SS Konzept der Transaktion 4.2 Konzept der Transaktion (1/4) Eine Transaktion ist ein in sich geschlossener,
Betriebliche Informationssysteme Prof. Dr. Michael Löwe
Ralf KüstersDagstuhl 2008/11/30 2 Ralf KüstersDagstuhl 2008/11/30 3.
Gottfried Vossen 5. Auflage 2008 Datenmodelle, Datenbanksprachen und Datenbankmanagementsysteme Kapitel 21: Concurrency Control.
Datenmodelle, Datenbanksprachen und Datenbankmanagementsysteme
Materialien zum Informatikunterricht (Pohlig-Häberle)
...ich seh´es kommen !.
Syntaxanalyse Bottom-Up und LR(0)
Mehrbenutzersynchronisation
Auslegung eines Vorschubantriebes
WS 2012/13 Datenbanksysteme Mi 15:15 – 16:45 R Vorlesung #11 Transaktionsverwaltung.
WS 2004/2005 Datenbanken II - 5W Mi 17:00 – 18:30 G 3.18 Vorlesung #6 Fehlerbehandlung.
WS 2011/12 Datenbanksysteme Mi 15:15 – 16:45 R Vorlesung #10 Transaktionsverwaltung.
WS 2004/2005 Datenbanken II - 5W Mi 17:00 – 18:30 G 3.18 Vorlesung #7 Mehrbenutzersynchronisation (Teil 1)
Vorlesung #9 Fehlerbehandlung
Vorlesung Datenbanksysteme vom Physische Datenorganisation
Transaktion Huang Zhenhao FU Shuai.
Datenbanksysteme Technische Grundlagen Transaktions-Konzept, Mehrbenutzer-Synchronisation, Fehlerbehandlung Prof. Dr. Manfred Gruber FH München.
Analyseprodukte numerischer Modelle
Vorlesung Datenbanksysteme WS 2.0 Christoph Koch (Subject: DBVO:...
ADAT©2004,2006 Dipl. - Ing. Walter SabinSeite: 48 Version 1.0a Recovery Wiederherstellung eines konsistenten Datenbankzustandes nach Fehlersituationen.
Schutzvermerk nach DIN 34 beachten 20/05/14 Seite 1 Grundlagen XSoft Lösung :Logische Grundschaltung IEC-Grundlagen und logische Verknüpfungen.
Lokales 2-Phasen-Festschreibe- Protokoll Segment-Verwalter führt commit(T i ) in zwei Phasen aus: Phase 1: Sicherstellung der Wiederholbarkeit. –Für jedes.
Der Erotik Kalender 2005.
Fehlerbehandlung (Recovery)
Transaktionsverwaltung
Wiederanlauf nach Systemzusammenbruch Aufgabe: Bei Noforce-Strategie Wiederholung aller noch nicht in die Datenbasis eingebrachten Änderungen bereits abgeschlossener.
Recovery    AIFB SS Grundlegende Annamen(1/2) Um den Erfolg der der Recovery-Maßnahmen zu gewährleisten, werden folgende Annahmen.
Monatsbericht Ausgleichsenergiemarkt Gas – Oktober
Sicherung gegen Medienverlust (1) Medienverlust = Verlust der Datenbasis und/oder des Protokolls. Vorbeugung durch periodische Sicherung von Datenbasis.
Recovery    AIFB SS (1/6) Durchführung der Recovery-Maßnahmen(1/6) Transaktions-Fehler (TF) T1 T2 T3 Zeitt Transaktion T2 wird vom.
unpin(a,b,c) flush(a,b,c)
Transaktionsverwaltung Beispiel einer typischen Transaktion in einer Bankanwendung: 1.Lese den Kontostand von A in die Variable a: read(A,a); 2.Reduziere.
Prof. Dr. T. Kudraß1 Transaktionsmanagement - Einführung.
Transaktionsverwaltung Beispiel einer typischen Transaktion in einer Bankanwendung: 1.Lese den Kontostand von A in die Variable a: read(A,a); 2.Reduziere.
Übung – Recovery Manager Undo Redo Algorithmus
Vorlesung #7 Fehlerbehandlung
Transaktionsabbruch, System Crash, Media Failure
Vorlesung #7 Fehlerbehandlung
Vorlesung #7 Fehlerbehandlung
Vorlesung #10 Fehlerbehandlung
Redo/Undo Ersetzungsstrategie: LRU
 Präsentation transkript:

1 Fehlerbehandlung (Recovery) 1.Lokaler Fehler in einer noch nicht festgeschriebenen (committed) Transaktion Wirkung muss zurückgesetzt werden R1-Recovery 2.Fehler mit Hauptspeicherverlust Abgeschlossene TAs müssen erhalten bleiben (R2-Recovery) Noch nicht abgeschlossene TAs müssen zurückgesetzt werden (R3-Recovery) 3.Fehler mit Hintergrundspeicherverlust R4-Recovery Fehlerklassifikation

2 Zweistufige Speicherhierarchie C A D DBMS-Puffer A D C B PAPA PBPB PCPC Hintergrundspeicher Einlagerung Auslagerung

3 Die Speicherhierarchie Ersetzung von Puffer-Seiten ¬steal: Bei dieser Strategie wird die Ersetzung von Seiten, die von einer noch aktiven Transaktion modifiziert wurden, ausgeschlossen. steal: Jede nicht fixierte Seite ist prinzipiell ein Kandidat für die Ersetzung, falls neue Seiten eingelagert werden müssen. Einbringen von Änderungen abgeschlossener TAs Force-Strategie: Änderungen werden zum Transaktionsende auf den Hintergrundspeicher geschrieben. ¬force-Strategie: geänderte Seiten können im Puffer verbleiben.

4 Auswirkungen auf Recovery force¬force ¬steal kein Undo kein Redo Redo kein Undo steal kein Redo Undo Redo Undo

5 Einbringungsstrategie Update in Place jede Seite hat genau eine Heimat auf dem Hintergrundspeicher der alte Zustand der Seite wird überschrieben Twin-Block-Verfahren Anordnung der Seiten P A, P B, und P C. Schattenspeicherkonzept nur geänderte Seiten werden dupliziert weniger Redundanz als beim Twin-Block-Verfahren

6 Hier zugrunde gelegte Sytemkonfiguration steal -dreckige Seiten können in der Datenbank (auf Platte) geschrieben werden ¬force -geänderte Seiten sind möglicherweise noch nicht auf die Platte geschrieben update-in-place -Es gibt von jeder Seite nur eine Kopie auf der Platte Kleine Sperrgranulate -auf Satzebene -also kann eine Seite gleichzeitig dreckige Daten (einer noch nicht abgeschlossenen TA) und committed updates enthalten -das gilt sowohl für Puffer – als auch Datenbankseiten

7 Protokollierung von Änderungsoperationen LSN (Log Sequence Number), eine eindeutige Kennung des Log-Eintrags. LSNs müssen monoton aufsteigend vergeben werden, die chronologische Reihenfolge der Protokolleinträge kann dadurch ermittelt werden. Transaktionskennung TA der Transaktion, die die Änderung durchgeführt hat. PageID die Kennung der Seite, auf der die Änderungsoperationen vollzogen wurde. Wenn eine Änderung mehr als eine Seite betrifft, müssen entsprechend viele Log-Einträge generiert werden. Struktur der Log-Einträge [LSN, TransaktionsID, PageID, Redo, Undo, PrevLSN]

8 Protokollierung von Änderungsoperationen II Die Redo -Information gibt an, wie die Änderung nachvollzogen werden kann. Die Undo -Information beschreibt, wie die Änderung rückgängig gemacht werden kann. PrevLSN, einen Zeiger auf den vorhergehenden Log-Eintrag der jeweiligen Transaktion. Diesen Eintrag benötigt man aus Effizienzgründen. Struktur der Log-Einträge II [LSN, TransaktionsID, PageID, Redo, Undo, PrevLSN]

9 Beispiel einer Log-Datei SchrittT1T1 T2T2 Log [LSN, TA, PageID, Redo, Undo, PrevLSN] 1.BOT[#1,T 1,BOT,0] 2.r(A,a 1 ) 3.BOT[#2,T 2,BOT,0] 4.r(C,c 2 ) 5.a 1 := a w(A,a 1 )[#3,T 1,P A,A-=50,A+=50,#1] 7.c 2 := c w(C,c 2 )[#4,T 2,P C,C+=100,C-=100,#2] 9.r(B,b 1 ) 10.b 1 := b w(B,b 1 )[#5,T 1,P B,B+=50,B-=50,#3] 12.commit[#6,T 1,commit,#5] 13.r(A,a 2 ) 14.a 2 := a 2 – w(A,a 2 )[#7,T 2,P A,A-=100,A+=100,#4] 16.commit[#8,T 2,commit,#7]

10 Logische oder physische Protokollierung Physische Protokollierung Es werden Inhalte / Zustände protokolliert: 1.before-image enthält den Zustand vor Ausführung der Operation 2.after-image enthält den Zustand nach Ausführung der Operation Logische Protokollierung das Before-Image wird durch Ausführung des Undo- Codes aus dem After-Image generiert und das After-Image durch Ausführung des Redo-Codes aus dem Before-Image berechnet. Speicherung der Seiten-LSN Die Herausforderung besteht darin, beim Wiederanlauf zu entscheiden, ob man das Before- oder das After-Image auf dem Hintergrundspeicher vorgefunden hat. Dazu wird auf jeder Seite die LSN des jüngsten diese Seite betreffenden Log-Eintrags gespeichert.

Schattenspeicher-Verfahren

12 Illustration: Seiten-LSN C A D DBMS-Puffer A D C B PAPA PBPB PCPC Hintergrundspeicher Einlagerung Auslagerung

13 Schreiben der Log-Information DBMS- Code AP 1 AP n · · · Log- Puffer Datenbank- Puffer Log-DateiDatenbasis Log- Archiv DB- Archiv

14 Schreiben der Log-Information Die Log-Information wird zweimal geschrieben 1.Log-Datei für schnellen Zugriff -R1, R2 und R3-Recovery 2.Log-Archiv -R4-Recovery

15 Anordnung des Log-Ringpuffers #10 #30 #20 #41 #40 Log-Datei Log- Archiv... ausschreiben eintragen...

16 Das WAL-Prinzip Write Ahead Log-Prinzip 1.Bevor eine Transaktion festgeschrieben (committed) wird, müssen alle zu ihr gehörenden Log-Einträge ausgeschrieben werden. 2.Bevor eine modifizierte Seite ausgelagert werden darf, müssen alle Log-Einträge, die zu dieser Seite gehören, in das temporäre und das Log-Archiv ausgeschrieben werden.

17 Wiederanlauf nach einem Fehler Transaktionen der Art T 1 müssen hinsichtlich ihrer Wirkung vollständig nachvollzogen werden. Transakionen dieser Art nennt man Winner. Transaktionen, die wie T 2 zum Zeitpunkt des Absturzes noch aktiv waren, müssen rückgängig gemacht werden. Diese Transaktionen bezeichnen wir als Loser. Zeitachse T2T2 T1T1 t1t1 t2t2 t3t3 Absturz Transaktionsbeginn und – ende relativ zu einem Systemabsturz

18 Drei Phasen des Wiederanlaufs 1.Analyse: Die temporäre Log-Datei wird von Anfang bis zum Ende analysiert, Ermittlung der Winner-Menge von Transaktionen des Typs T 1 Ermittlung der Loser-Menge von Transaktionen der Art T 2. 2.Wiederholung der Historie: alle protokollierten Änderungen werden in der Reihenfolge ihrer Ausführung in die Datenbasis eingebracht. 3.Undo der Loser: Die Änderungsoperationen der Loser-Transaktionen werden in umgekehrter Reihenfolge ihrer ursprünglichen Ausführung rückgängig gemacht.

19 Wiederanlauf in drei Phasen Log 1.Analyse 2. Redo aller Änderungen (Winner und Loser) 3. Undo aller Loser-Änderungen Fehlertoleranz (Idempotenz) des Wiederanlaufs undo(undo(...(undo(a))...)) = undo(a) redo(redo(...(redo(a))...)) = redo(a) auch während der Recoveryphase kann das System abstürzen

20 Beispiel einer Log-Datei SchrittT1T1 T2T2 Log [LSN, TA, PageID, Redo, Undo, PrevLSN] 1.BOT[#1,T 1,BOT,0] 2.r(A,a 1 ) 3.BOT[#2,T 2,BOT,0] 4.r(C,c 2 ) 5.a 1 := a w(A,a 1 )[#3,T 1,P A,A-=50,A+=50,#1] 7.c 2 := c w(C,c 2 )[#4,T 2,P C,C+=100,C-=100,#2] 9.r(B,b 1 ) 10.b 1 := b w(B,b 1 )[#5,T 1,P B,B+=50,B-=50,#3] 12.commit[#6,T 1,commit,#5] 13.r(A,a 2 ) 14.a 2 := a 2 – w(A,a 2 )[#7,T 2,P A,A-=100,A+=100,#4] 16.commit[#8,T 2,commit,#7]

21 Kompensationseinträge im Log #1#6#5#3#4#2#7 T1T1 T2T2 #1#6#5 #3#3 #4#2#7 #2#4 UndoNxtLSN Wiederanlauf und Log Kompensationseinträge (CLR: compensating log record) für rückgängig gemachte Änderungen. -#7 ist CLR für #7 -#4 ist CLR für #4

22

23 Logeinträge nach abgeschlossenem Wiederanlauf [#1,T 1,BOT,0] [#2,T 2,BOT,0] [#3,T 1,P A,A-=50,A+=50,#1] [#4,T 2,P C,C+=100,C-=100,#2] [#5,T 1,P B,B+=50,B-=50,#3] [#6,T 1,commit,#5] [#7,T 2,P A,A-=100,A+=100,#4]

24 Logeinträge nach abgeschlossenem Wiederanlauf II CLRs sind durch spitze Klammern gekennzeichnet. der Aufbau eines CLR ist wie folgt -LSN -TA-Identifikator -betroffene Seite -Redo-Information -PrevLSN -UndoNxtLSN (Verweis auf die nächste rückgängig zu machende Änderung) CLRs enthalten keine Undo-Information -warum nicht?

25 Lokales Zurücksetzen einer Transaktion Schritte 3 und 4 werden zurückgenommen notwendig für die Realisierung von Sicherungspunkten innerhalb einer TA Historie Log... #2#4 #3#5#1#3 Partielles Zurücksetzen einer Transaktion

26 prüfen MatrNrVorlNrPersNrNote

27 Sicherungspunkte Zeitachse T1T1 Absturz Transaktionskonsistente Sicherungspunkte Sicherungspunkt S i-1 Sicherungspunkt S i angemeldet Sicherungspunkt S i geschrieben T2T2 T3T3 T4T4

28 Drei unterschiedliche Sicherungspunkt-Qualitäten Log Sicherungspunkt (a) transaktionskonsistent (b) aktionskonsistent (c) unscharf (fuzzy) Analyse Redo Undo Analyse Redo Undo Analyse Redo Undo MinDirtyPageLSN MinLSN

29 Aktionskonsistente Sicherungspunkte Zeitachse T1T1 Systemabsturz T2T2 T4T4 T5T5 Sicherungspunkt Transaktionsausführung relativ zu einem aktions- konsistenten Sicherungspunkt und einem Systemabsturz T3T3

30 Unscharfe (fuzzy) Sicherungspunkte modifizierte Seiten werden nicht ausgeschrieben nur deren Kennung wird ausgeschrieben -Dirty Pages = Menge der modifizierten Seiten MinDirtyPageLSN: die minimale LSN, deren Änderungen noch nicht ausgeschrieben wurde MinLSN: die kleinste LSN der zum Sicherungszeitpunkt aktiven TAs

31 R4-Recovery / Media-Recovery Recovery nach einem Verlust der materialisierten Datenbasis materialisierte Datenbasis Datenbasis- Archiv Log- Archiv temporäre Log-Datei Fehler konsistente Datenbasis