Elméleti kérdések: ------------------ Írja le az UNDO naplózás szabályait és a lemezre írások sorrendjét. Adja meg a helyreállítás lépéseit UNDO napló esetén. Adja meg az egyszerű ellenőrzőpont képzés lépéseit. Adja meg a működés közbeni ellenőrzőpont képzés lépéseit UNDO napló esetén. Írja le a REDO naplózás szabályait és a lemezre írások sorrendjét. Adja meg a helyreállítás lépéseit REDO napló esetén. Adja meg a működés közbeni ellenőrzőpont képzés lépéseit REDO napló esetén. Adja meg a működés közbeni ellenőrzőpont képzés lépéseit UNDO/REDO napló esetén. -------------------------------------------------------------------------------- Állapítsuk meg néhány, konkrét művelettel megadott tranzakcióról, hogy megőrzik-e az adatbázis konzisztenciáját. A konzisztencia megadott feltétellel van definiálva. (lásd naplo.ppt 22. old.) 8.1.1 Feladat (könyv 463. old.) Tegyük fel, hogy az adatbázisra vonatkozó konzisztenciamegszorítás: 0 <= A <= B. Állapítsuk meg, hogy a következő tranzakciók megőrzik-e az adatbázis konzisztenciáját. T1: A := A+B; B := A+B; A:=A-8 T2: B := A+B; A := A+B; B:=B+10 T3: A := B+1; B := A+2; A:=A+1 -------------------------------------------------------------------------------- Adjuk meg néhány, konkrét művelettel megadott tranzakció esetén az adatbáziselemek memóriabeli és lemezen levő értékét az egyes műveletek után. (lásd naplo.ppt 43. old.) A tranzakció által elvégzett egyes műveletek: INPUT(X): X adatbáziselem (az őt tartalmazó adatblokk) beolvasása lemezről a közös memóriapufferbe. READ(X,t): X adatbáziselem beolvasása a tranzakció t lokális változójába. t:= ... Értékadás a lokális változónak. WRITE(X,t): t érték beírása X adatbáziselembe a memóriapufferben. OUTPUT(X): X adatbáziselem (az őt tartalmazó adatblokk) kiírása lemezre a közös memóriapufferből. 8.1.2 Feladat (könyv 463. old.) A 8.1.1 feladat mindegyik tranzakciójához a számításokon kívül tegyük hozzá a READ, WRITE műveleteket, és a lokális változók műveleteit, és mutassuk be a tranzakciók lépésenkénti hatását a memóriában és a lemezen tárolt adatokra. Tegyük fel, hogy kezdetben A = 5 és B = 10. -------------------------------------------------------------------------------- Megjegyzés: A és , illetve és ugyanazt jelenti. Az Ullman könyvben az egyik, az előadás diákon a másik sorrend szerepel. Adjuk meg néhány tranzakció semmisségi naplóbejegyzéseit. UNDO naplózás szabályai és lemezre írások sorrendje: 1. naplóbejegyzések kiírása lemezre 2. Output(X) módosított adatelemek kiírása lemezre (-> a gond, hogy túl sokszor kell lemezre írni) 3. naplóbejegyzés kiírása lemezre 8.2.1 Feladat (könyv 476. old.) Adjuk meg a 8.1.1 feladatban szereplő tranzakciók semmisségi (undo) naplóbejegyzéseit. Tegyük fel, hogy kezdetben A = 5 és B = 10. -------------------------------------------------------------------------------- Adjuk meg egy UNDO napló alapján a helyreállításhoz szükséges műveleteket a megfelelő sorrendben. A műveletek, amiket megfelelő sorrendben el kell végezni: WRITE(), OUTPUT(), (naplóbejegyzés írása memóriába), FLUSH LOG (napló lemezre írása) Helyreállítás: A COMMIT-tal nem rendelkező (és ABORT-tal nem rendelkező) tranzakciók műveleteit fordított sorrendben (hátulról előre) megsemmisítjük, vagyis vissza írjuk a régi értéket az elembe (WRITE) majd a lemezre (OUTPUT). A végén -t írunk a naplóba és kiírjuk lemezre a naplót (FLUSH LOG). 8.2.4 Feladat (könyv 476. old.) A következő naplóbejegyzés-sorozat a T, U és V tranzakciókra vonatkozik: Adjuk meg a helyreállítás-kezelő tevékenységeit, ha az utolsó lemezre került naplóbejegyzés: a) b) c) d) e) -------------------------------------------------------------------------------- Ellenőrzőpont képzés Egyszerű: megvárni az aktív tranzakciók befejeződését, addig újat nem engedni, majd írása a naplóba + FLUSH LOG Működés közbeni: a naplóba majd FLUSH LOG megvárni az aktív tranzakciók befejeződését, közben indulhatnak újak majd a naplóba + FLUSH LOG A helyreállításhoz elég visszafelé a legutóbbi előtti -ig visszamenni. Ha visszafelé haladva -val találkozunk előbb, akkor elég a legkorábbi, be nem fejezett Ti-re vonatkozó -ig visszamenni. -------------------------------------------------------------------------------- 8.2.7 Feladat (könyv 477. old.) ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; Tegyük fel, hogy működés közbeni ellenőrzőpontot képzünk a következő naplóbejegyzések után: Mikor íródik fel az ? Meddig kell a naplóban visszafelé mennünk ha hiba lép fel? különböző helyekre adjuk meg -------------------------------------------------------------------------------- 8.3.1 Feladat (könyv 483. old.) Adjuk meg a 8.1.1 feladatban szereplő tranzakciók helyreállítási (REDO) típusú naplóbejegyzéseit. Tegyük fel, hogy kezdetben A = 5 és B = 10. REDO naplózás szabályai és a lemezre írások sorrendje: 1. naplóbejegyzések kiírása lemezre 2. naplóbejegyzés kiírása lemezre 3. Output(X) módosított elemek kiírása lemezre (-> a gond, hogy túl sokáig nem szabad lemezre írni) 4. naplóbejegyzés kiírása a lemezre -------------------------------------------------------------------------------- Adjuk meg egy REDO napló alapján a helyreállításhoz szükséges műveleteket a megfelelő sorrendben. Helyreállítás: A COMMIT-tal rendelkező (de END-del nem rendelkező) tranzakciók műveleteit újból végrehajtani majd -t írni a naplóba + FLUSH LOG. Opcionálisan a be nem fejezett tranzakciókra -t lehet írni a naplóba a FLUSH LOG előtt. 8.3.3 Feladat (könyv 483. old.) Ismételjük meg a 8.2.4 feladatot helyreállítási (REDO) típusú naplózást használva. Adjuk meg a helyreállítás-kezelő tevékenységeit, ha az utolsó lemezre került naplóbejegyzés: a) b) c) d) e) -------------------------------------------------------------------------------- Ellenőrzőpont képzés (működés közbeni) + FLUSH LOG A START CKPT előtt befejeződött tranzakciók még lemezre nem írt módosításainak kiírása + FLUSH LOG A helyreállításhoz elég a legutóbbi előtti tranzakciói közül a legkorábbinak a kezdetéig -> -ig visszamenni -------------------------------------------------------------------------------- 8.4.1 Feladat (könyv 489. old.) Adjuk meg a 8.1.1 feladatban szereplő tranzakciók undo/redo típusú naplóbejegyzéseit. Tegyük fel, hogy kezdetben A = 5 és B = 10. UNDO/REDO naplózás szabályai és a lemezre írások sorrendje: 1. először a naplózást írjuk ki (), csak utána magát a módosítást (Output(X)) (a COMMIT-ot naplózhatjuk a módosítások kiírása előtt is vagy utána is) 2. amint a kiíródott a naplóba, a naplót nyomban lemezre is kiírjuk: FLUSH LOG -------------------------------------------------------------------------------- 8.4.3 Feladat (könyv 489. old.) A következő undo/redo naplóbejegyzés-sorozat a T és U két tranzakcióra vonatkozik: Adjuk meg a helyreállítás-kezelő tevékenységeit, ha az utolsó lemezre került naplóbejegyzés: a) b) c) d) e) Helyreállítás: A COMMIT-tal (és ABORT-tal) nem rendelkező tranzakciókat UNDO-zzuk, majd a naplóba -t írunk + FLUSH LOG. A COMMIT-tal rendelkező (de END-del nem rendelkező) tranzakciókat REDO-zzuk, majd a naplóba -t írunk + FLUSH LOG. -------------------------------------------------------------------------------- Ellenőrzőpont képzés + FLUSH LOG Az összes piszkos (módosított, de lemezre még nem kiírt) puffer lemezre írása + FLUSH LOG A helyreállításhoz elég a legutóbbi előtti tranzakciói közül a legkorábbinak a kezdetéig -> -ig visszamenni. Az UNDO műveleteket az iménti bejegyzésig visszamenve kell végrehajtani, a REDO műveleteket azonban elég a -től előrefelé haladva (lásd naplo.ppt 104-106 old.) Ha visszafelé haladva -vel találkozunk előbb, azt figyelmen kívül hagyjuk, és keressük visszafelé a legutóbbi -t.