J第7章數(shù)據(jù)庫恢復技術_第1頁
J第7章數(shù)據(jù)庫恢復技術_第2頁
J第7章數(shù)據(jù)庫恢復技術_第3頁
J第7章數(shù)據(jù)庫恢復技術_第4頁
J第7章數(shù)據(jù)庫恢復技術_第5頁
已閱讀5頁,還剩69頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領

文檔簡介

數(shù)據(jù)庫系統(tǒng)概論AnIntroductiontoDatabaseSystem第七章數(shù)據(jù)庫恢復技術1第七章數(shù)據(jù)庫恢復技術7.1事務的根本概念7.2數(shù)據(jù)庫恢復概述7.3故障的種類7.4恢復的實現(xiàn)技術7.5恢復策略27.1.1事務的根本概念事務處理技術包括數(shù)據(jù)庫恢復和并發(fā)控制技術。一、什么是事務?事務(Transaction)是用戶定義的一個數(shù)據(jù)庫操作序列,這些操作要么全做,要么全不做,是一個不可分割的工作單位DBMS將事務看作數(shù)據(jù)庫運行中的一個邏輯工作單位,由DBMS的事務管理子系統(tǒng)負責事務的控制和管理。事務是恢復和并發(fā)控制的根本單位3二、如何定義事務顯式定義方式

BEGINTRANSACTIONBEGINTRANSACTIONSQL語句1SQL語句1SQL語句2SQL語句2。。。。。。。。。。COMMITROLLBACK隱式方式當用戶沒有顯式地定義事務時,DBMS按缺省規(guī)定自動劃分事務4三、事務結(jié)束COMMIT事務正常結(jié)束提交事務的所有操作〔讀+更新〕事務中所有對數(shù)據(jù)庫的更新永久生效ROLLBACK事務異常終止事務運行的過程中發(fā)生了故障,不能繼續(xù)執(zhí)行回滾事務的所有更新操作事務回滾到開始時的狀態(tài)57.1.2實例[例1]將學生-選課數(shù)據(jù)庫中,英語課的課程編號由1156修改為2256。所涉及的關系:Course(Cno,Cname,Cpno,Ccredit)SC(Sno,Cno,Grade)根據(jù)參照完整性約束,應將兩表中的1156都改為2256。要將修改兩個表的兩個SQL語句定義成一個事務。DBMS對這兩個語句要么都執(zhí)行,要不都不執(zhí)行。6定義事務如下:BEGINTRANSACTIONUPDATECourseSETCno=‘2256’WHERECno=‘1156’;UPDATESCSETCno=‘2256’WHERECno=‘1156’;COMMIT7[例2]在銀行應用中,將賬戶A的1萬元

轉(zhuǎn)移到B賬戶中定義一個事務,該事務包括兩個操作:A=A-1萬B=B+1萬這兩個操作要么全做,要么全不做設有表:存款余額表(用戶標識,余額)在數(shù)據(jù)庫中為:Account(CID,Balance)8[例2]定義事務如下:EXECSQLBEGINETRANSACTIONEXECSQLUPDATEAccountSETBalance=Balance+10000WHERECID=‘B’;EXECSQLSELECTBalanceINTO:C_Balance/*取A帳戶余額到變量中*/FROMAccountWHERECID=‘A’;9IfC_Balance<10000/*如果余額不夠,*/Then{printf(“余額缺乏”),EXECSQLROLLBACK;/*回到開始狀態(tài),撤消給B帳戶的1萬元*/}Else{EXECSQLUPDATEAccount/*余額夠,帳戶A-1萬*/SETBalance=Balance-10000WHERECID=‘A’;EXECSQLCOMMIT;}事務和程序是兩個概念在關系數(shù)據(jù)庫中,一個事務可以是一條SQL語句,一組SQL語句或整個程序一個應用程序通常包含多個事務107.1.3事務的特性事務有4個特性(簡稱ACID特性):原子性〔Atomicity〕一致性〔Consistency〕隔離性〔Isolation〕持續(xù)性〔Durability〕111.原子性原子性指:事務是數(shù)據(jù)庫的邏輯工作單位,事務中包括的諸操作要么都做,要么都不做122.一致性事務執(zhí)行的結(jié)果必須是使數(shù)據(jù)庫從一個一致性狀態(tài)變到另一個一致性狀態(tài)一致性狀態(tài):數(shù)據(jù)庫中只包含成功事務提交的結(jié)果不一致狀態(tài):如果數(shù)據(jù)庫運行中發(fā)生故障,有些事務還沒完成就被迫中斷,事務對數(shù)據(jù)庫的修改有一局部已寫入數(shù)據(jù)表,這時數(shù)據(jù)庫就處于不一致狀態(tài)。13一致性與原子性是密切相關的。銀行轉(zhuǎn)帳:從帳號A中取出1萬元,存入帳號B。定義一個事務,該事務包括兩個操作這兩個操作要么全做,要么全不做(原子性)全做或者全不做(原子性),數(shù)據(jù)庫都處于一致性狀態(tài)。如果只做一個操作,數(shù)據(jù)庫就處于不一致性狀態(tài)。

B=B+1

A=A-1BA143.隔離性對多個事務并發(fā)執(zhí)行而言,一個事務的執(zhí)行不能被其他事務干擾。一個事務內(nèi)部的操作及使用的數(shù)據(jù)對其他并發(fā)事務是隔離的并發(fā)執(zhí)行的各個事務之間不能互相干擾15下例中,事務T1的修改被事務T2覆蓋了!所以T1與T2不是隔離的,是互相影響的.

讀A=16

A←讀出的A-3寫回A=13①讀A=16

③A←A-1寫回A=15④T2T1164.持續(xù)性持續(xù)性也稱永久性一個事務一旦提交,它對數(shù)據(jù)庫中數(shù)據(jù)的改變就應該是永久性的。接下來的其他操作或故障不應該對其執(zhí)行結(jié)果有任何影響。17事務的特性保證事務ACID特性是事務管理子系統(tǒng)的重要任務可能破壞事務ACID特性的因素:〔1〕多個事務并行運行時,不同事務的操作交叉執(zhí)行〔2〕事務在運行過程中被強行終止對于〔1〕情況,DBMS必須保證多個事務的交叉運行,不影響這些事務的原子性。對于〔2〕情況,DBMS必須保證被迫終止的事務對數(shù)據(jù)庫和其他事務沒有影響。這些就是DBMS的恢復機制和并發(fā)控制機制的責任。187.2數(shù)據(jù)庫恢復概述故障是不可防止的計算機硬件故障系統(tǒng)軟件和應用軟件的錯誤操作員的失誤惡意的破壞故障的影響輕那么造成運行事務非正常中斷重那么破壞數(shù)據(jù)庫,使數(shù)據(jù)喪失因此,DBMS必須具有將數(shù)據(jù)庫從錯誤狀態(tài)恢復到某一的正確〔一致〕狀態(tài)的功能。這就是數(shù)據(jù)庫恢復功能。19數(shù)據(jù)庫恢復概述〔續(xù)〕數(shù)據(jù)庫管理系統(tǒng)對故障的對策DBMS提供恢復子系統(tǒng)(是DBMS的重要局部)它保證故障發(fā)生后,能把數(shù)據(jù)庫中的數(shù)據(jù)從錯誤狀態(tài)恢復到某種邏輯一致的狀態(tài)保證事務的〔四個〕ACID特性。恢復技術是衡量系統(tǒng)優(yōu)劣的重要指標207.3

故障的種類數(shù)據(jù)庫系統(tǒng)可能發(fā)生的故障:事務故障系統(tǒng)故障介質(zhì)故障計算機病毒21、事務內(nèi)部故障什么是事務故障某個事務在運行過程中由于種種原因未運行至正常終點就終止了造成事務非正常終止的原因有的可以通過事務程序本身發(fā)現(xiàn),如[例2]中,帳戶A的余額缺乏,那么終止事務的執(zhí)行,讓事務回滾,撤消已做的修改,恢復數(shù)據(jù)庫到正確狀態(tài);有的故障是非預期的,不能由事務程序自己來處理。22事務故障的常見原因輸入數(shù)據(jù)有誤運算溢出違反了某些完整性限制某些應用程序出錯并行事務發(fā)生死鎖。。。。23事務故障的恢復發(fā)生事務故障時,夭折的事務可能已把對數(shù)據(jù)庫的局部修改寫回磁盤事務故障的恢復:撤消事務〔UNDO〕強行回滾〔ROLLBACK〕該事務,去除該事務對數(shù)據(jù)庫的所有修改,使得這個事務象根本沒有啟動過一樣247.3.2系統(tǒng)故障什么是系統(tǒng)故障系統(tǒng)故障是指造成系統(tǒng)停止運轉(zhuǎn)的任何事件,使得系統(tǒng)要重新啟動。系統(tǒng)故障的常見原因特定類型的硬件錯誤〔如CPU故障〕突然停電操作系統(tǒng)或DBMS代碼錯誤操作員操作失誤25系統(tǒng)故障造成:整個系統(tǒng)的正常運行突然被破壞所有正在運行的事務都非正常終止內(nèi)存中數(shù)據(jù)庫緩沖區(qū)的信息全部喪失外部存儲設備上的數(shù)據(jù)未受影響即,這類故障影響正在運行的所有事務,但不破壞數(shù)據(jù)庫.26系統(tǒng)故障的恢復恢復子系統(tǒng)在系統(tǒng)重新啟動時做到:去除尚未完成的事務對數(shù)據(jù)庫的所有修改系統(tǒng)重新啟動時,恢復程序要讓所有非正常終止的事務回滾,強行撤消〔UNDO〕所有未完成事務277.3.3介質(zhì)故障系統(tǒng)故障稱為軟故障,介質(zhì)故障稱為硬故障。硬故障指外存故障。如:硬盤損壞、磁頭碰撞、瞬時強磁場干擾等。硬件故障使存儲在外存中的數(shù)據(jù)局部喪失或全部喪失。這類故障將破壞數(shù)據(jù)庫或破壞局部數(shù)據(jù)庫,并影響正在存取這局部數(shù)據(jù)的事務。介質(zhì)故障比前兩類故障的可能性小得多,但破壞性大得多287.3.4計算機病毒這是人為的故障或破壞,是一種計算機程序這種程序像病毒一樣可以繁殖和傳播,并造成對計算機系統(tǒng)包括數(shù)據(jù)庫的危害。計算機病毒已成為計算機系統(tǒng)的主要威脅,也是數(shù)據(jù)庫系統(tǒng)的主要威脅。計算機平安工作者已研制了許多防病毒和查、殺病毒的軟件。但還沒有使計算機終生免疫的“疫苗”。因此數(shù)據(jù)庫一旦被破壞,仍要用恢復技術對數(shù)據(jù)庫進行恢復。29總結(jié)各類故障,對數(shù)據(jù)庫的影響有兩種可能:一是數(shù)據(jù)庫本身被破壞,二是數(shù)據(jù)庫沒有破壞,但數(shù)據(jù)不正確〔不一致〕,是因為事務的非正常終止造成的。30恢復操作的根本原理恢復操作的根本原理:冗余利用存儲在系統(tǒng)其它地方的冗余數(shù)據(jù)來重建數(shù)據(jù)庫中已被破壞或不正確的那局部數(shù)據(jù)盡管恢復操作的根本原理很簡單,恢復的實現(xiàn)技術卻復雜一個大型數(shù)據(jù)庫產(chǎn)品,恢復子系統(tǒng)的代碼要占全部代碼的10%以上317.4恢復的實現(xiàn)技術恢復機制涉及的關鍵問題:1.如何建立冗余數(shù)據(jù)數(shù)據(jù)轉(zhuǎn)儲〔backup〕登錄日志文件〔Logging〕2.如何利用這些冗余數(shù)據(jù)實施數(shù)據(jù)庫恢復

327.4.1數(shù)據(jù)轉(zhuǎn)儲一、什么是轉(zhuǎn)儲二、轉(zhuǎn)儲的用途三、轉(zhuǎn)儲方法33一、什么是轉(zhuǎn)儲轉(zhuǎn)儲是指DBA定期地將整個數(shù)據(jù)庫復制到另一個磁盤上保存起來的過程。這些備用的數(shù)據(jù)文本稱為后備副本或后援副本。二、轉(zhuǎn)儲的用途當數(shù)據(jù)庫遭到破壞時,可以將后備副本重新裝入。但重裝后備副本只能將數(shù)據(jù)庫恢復到轉(zhuǎn)儲時的狀態(tài)。要恢復到故障發(fā)生時的狀態(tài),需要重新運行自轉(zhuǎn)儲以后的所有更新事務。34例如:

故障發(fā)生點

轉(zhuǎn)儲

運行事務↓正常運行─┼───────┼─────────────TaTbTf

重裝后備副本

重新運行事務恢復

─┼───────┴--------→此處停止運行事務,開始轉(zhuǎn)儲。轉(zhuǎn)儲完畢,得到Tb時刻的數(shù)據(jù)庫副本。然后繼續(xù)運行事務。重裝后備副本,將數(shù)據(jù)恢復到Tb時刻的狀態(tài)重新運行Tb~Tf時刻的所有更新事務,將數(shù)據(jù)恢復到故障發(fā)生前的狀態(tài)35三、轉(zhuǎn)儲方法轉(zhuǎn)儲十分消耗時間和資源,不能頻繁進行.DBA應根據(jù)數(shù)據(jù)庫使用情況,確定一個適當?shù)霓D(zhuǎn)儲周期.轉(zhuǎn)儲分為:1.靜態(tài)轉(zhuǎn)儲與動態(tài)轉(zhuǎn)儲2.海量轉(zhuǎn)儲與增量轉(zhuǎn)儲361.靜態(tài)轉(zhuǎn)儲靜態(tài)轉(zhuǎn)儲是指在系統(tǒng)中無運行事務時進行轉(zhuǎn)儲轉(zhuǎn)儲開始時數(shù)據(jù)庫處于一致性狀態(tài)轉(zhuǎn)儲期間不允許對數(shù)據(jù)庫做任何存取、修改活動.優(yōu)點:實現(xiàn)簡單,得到的是一致性的數(shù)據(jù)副本。缺點:降低了數(shù)據(jù)庫的可用性轉(zhuǎn)儲必須等用戶事務結(jié)束新的事務必須等轉(zhuǎn)儲結(jié)束37利用靜態(tài)轉(zhuǎn)儲副本進行恢復

故障發(fā)生點

靜態(tài)轉(zhuǎn)儲

運行事務↓正常運行─┼───────┼─────────────TaTbTf

重裝后備副本

恢復

─┼───────┥此處停止運行事務,進行轉(zhuǎn)儲。轉(zhuǎn)儲完畢,得到Tb時刻的數(shù)據(jù)庫副本。然后繼續(xù)運行事務。重裝后備副本,將數(shù)據(jù)恢復到Tb時刻的狀態(tài)382.動態(tài)轉(zhuǎn)儲轉(zhuǎn)儲操作與用戶事務并發(fā)進行轉(zhuǎn)儲期間允許對數(shù)據(jù)庫進行存取或修改優(yōu)點不用等待正在運行的用戶事務結(jié)束不會影響新事務的運行缺點不能保證副本中的數(shù)據(jù)正確有效39例如,動態(tài)轉(zhuǎn)儲問題

A=100轉(zhuǎn)儲─┼───────┼──────┼──────TaTbTc

A=200

運行事務─────────────────┼──

TdTc時刻,將A=100轉(zhuǎn)儲到磁盤上。Td時刻,運行的事務,將A改為200可見,轉(zhuǎn)儲結(jié)束時,副本上的A=100數(shù)據(jù)已經(jīng)過時了。因此需要把動態(tài)轉(zhuǎn)儲期間各事務對數(shù)據(jù)庫的修改活動登記下來40動態(tài)轉(zhuǎn)儲利用動態(tài)轉(zhuǎn)儲得到的副本進行故障恢復需要把動態(tài)轉(zhuǎn)儲期間各事務對數(shù)據(jù)庫的修改活動登記下來,建立日志文件(LogFile)后備副本加上日志文件才能把數(shù)據(jù)庫恢復到某一時刻的正確狀態(tài)412.海量轉(zhuǎn)儲與增量轉(zhuǎn)儲海量轉(zhuǎn)儲:每次轉(zhuǎn)儲全部數(shù)據(jù)庫增量轉(zhuǎn)儲:只轉(zhuǎn)儲上次轉(zhuǎn)儲后更新過的數(shù)據(jù)海量轉(zhuǎn)儲與增量轉(zhuǎn)儲比較從恢復角度看,使用海量轉(zhuǎn)儲得到的后備副本進行恢復往往更方便但如果數(shù)據(jù)庫很大,事務處理又十分頻繁,那么增量轉(zhuǎn)儲方式更實用更有效423.轉(zhuǎn)儲方法小結(jié)轉(zhuǎn)儲方法分類

轉(zhuǎn)儲狀態(tài)動態(tài)轉(zhuǎn)儲靜態(tài)轉(zhuǎn)儲轉(zhuǎn)儲方式海量轉(zhuǎn)儲動態(tài)海量轉(zhuǎn)儲靜態(tài)海量轉(zhuǎn)儲增量轉(zhuǎn)儲動態(tài)增量轉(zhuǎn)儲靜態(tài)增量轉(zhuǎn)儲43轉(zhuǎn)儲策略應定期進行數(shù)據(jù)轉(zhuǎn)儲,制作后備副本。但轉(zhuǎn)儲又是十分消耗時間和資源的,不能頻繁進行。DBA應該根據(jù)數(shù)據(jù)庫使用情況確定適當?shù)霓D(zhuǎn)儲周期和轉(zhuǎn)儲方法。例:每天晚上進行動態(tài)增量轉(zhuǎn)儲每周進行一次動態(tài)海量轉(zhuǎn)儲每月進行一次靜態(tài)海量轉(zhuǎn)儲447.4.2登記日志文件一、日志文件的內(nèi)容二、日志文件的用途三、登記日志文件的原那么45一、日志文件的內(nèi)容1.什么是日志文件日志文件(log)是用來記錄事務對數(shù)據(jù)庫的更新操作的文件2.日志文件的格式有以下兩種:以記錄為單位的日志文件以數(shù)據(jù)塊為單位的日志文件46日志文件的內(nèi)容〔續(xù)〕3.日志文件內(nèi)容主要包括:各個事務的開始標記(BEGINTRANSACTION)各個事務的結(jié)束標記(COMMIT或ROLLBACK)各個事務的所有更新操作每個事務的以上內(nèi)容作為日志文件中的一個日志記錄(logrecord)474.基于記錄的日志文件每條日志記錄的內(nèi)容主要包括:事務標識〔標明是哪個事務〕操作類型〔插入、刪除或修改〕操作對象〔記錄內(nèi)部標識〕更新前數(shù)據(jù)的舊值〔對插入操作而言,此項為空值〕更新后數(shù)據(jù)的新值〔對刪除操作而言,此項為空值〕485.以數(shù)據(jù)塊為單位的日志文件每條日志記錄的內(nèi)容包括:事務標識〔標明是哪個事務〕更新前數(shù)據(jù)所在的整個數(shù)據(jù)塊的值〔對插入操作而言,此項為空值〕更新后整個數(shù)據(jù)塊的值〔對刪除操作而言,此項為空值〕49二、日志文件的用途日志文件在數(shù)據(jù)庫恢復中起著重要的作用。如:進行事務故障恢復進行系統(tǒng)故障恢復協(xié)助后備副本進行介質(zhì)故障恢復50日志文件的用途〔續(xù)〕具體作用:〔1〕事務故障和系統(tǒng)故障恢復必須用日志文件。〔2〕日志文件與靜態(tài)轉(zhuǎn)儲后備副本配合進行介質(zhì)故障恢復靜態(tài)轉(zhuǎn)儲的數(shù)據(jù)已是一致性的數(shù)據(jù)如果靜態(tài)轉(zhuǎn)儲完成后,仍能定期轉(zhuǎn)儲日志文件,那么在出現(xiàn)介質(zhì)故障重裝數(shù)據(jù)副本后,可以利用這些日志文件副本對已完成的事務進行重做處理這樣不必重新運行那些已完成的事務程序就可把數(shù)據(jù)庫恢復到故障前某一時刻的正確狀態(tài)51日志文件的用途〔續(xù)〕

故障發(fā)生點

靜態(tài)轉(zhuǎn)儲運行事務↓正常運行─┼──────┼──────────┼──TaTbTf

登記日志文件└───────────┴──

重裝后備副本利用日志文件恢復事務繼續(xù)運行介質(zhì)故障恢復─────────┴-----─-------┴──────

登記日志文件└──────52日志文件的用途〔續(xù)〕〔3〕在動態(tài)轉(zhuǎn)儲方式中建立日志文件,LOGFILE+動態(tài)轉(zhuǎn)儲后備副本進行有效的介質(zhì)故障恢復動態(tài)轉(zhuǎn)儲數(shù)據(jù)庫,同時轉(zhuǎn)儲同一時點的日志文件后備副本與該日志文件結(jié)合起來才能將數(shù)據(jù)庫恢復到一致性狀態(tài)。利用這些日志文件副本進一步恢復事務,防止重新運行事務程序。53利用動態(tài)轉(zhuǎn)儲副本進行恢復

Ta運行事務TbTf

動態(tài)轉(zhuǎn)儲

運行事務

故障發(fā)生點正常運行─┼───────┼─────────────登記日志文件登記新日志文件─────────┼─────────────

轉(zhuǎn)儲日志文件

重裝后備副本+用轉(zhuǎn)儲的日志文件恢復恢復到一

━━━━━━┥致性狀態(tài)54三、登記日志文件的原那么為保證數(shù)據(jù)庫是可恢復的,登記日志文件時必須遵循兩條原那么登記的次序嚴格按并發(fā)事務執(zhí)行的時間次序必須先寫日志文件,后寫數(shù)據(jù)庫先寫日志文件操作:把表示對數(shù)據(jù)庫修改的日志記錄寫到日志文件中后寫數(shù)據(jù)庫操作:把對數(shù)據(jù)的修改寫到數(shù)據(jù)庫中55登記日志文件的原那么〔續(xù)〕為什么要先寫日志文件寫數(shù)據(jù)庫和寫日志文件是兩個不同的操作在這兩個操作之間可能發(fā)生故障如果先寫了數(shù)據(jù)庫修改,而在日志文件中沒有登記下這個修改,那么以后就無法恢復這個修改了如果先寫日志,但沒有修改數(shù)據(jù)庫,按日志文件恢復時只不過是多執(zhí)行一次不必要的撤消〔UNDO〕操作,并不會影響數(shù)據(jù)庫的正確性567.5恢復策略7.5.1事務故障的恢復7.5.2系統(tǒng)故障的恢復7.5.3介質(zhì)故障的恢復577.5.1事務故障的恢復事務故障:是指事務在運行至正常終止點之前被終止。恢復方法由恢復子系統(tǒng)利用日志文件撤消〔UNDO〕此事務已對數(shù)據(jù)庫進行的修改事務故障的恢復由系統(tǒng)自動完成,不需要用戶干預58DBMS執(zhí)行事務故障的恢復步驟1.反向掃描日志文件〔即從最后向前掃描日志文件〕,查找該事務的更新操作。2.對該事務的更新操作執(zhí)行逆操作。即,將日志記錄中“更新前的值”寫入數(shù)據(jù)庫。登記的插入操作,“更新前的值”為空,那么恢復時相當于做刪除操作登記的刪除操作,“更新后的值”為空,那么恢復時相當于做插入操作假設登記的是修改操作,那么用更新前的值代替更新后的值59事務故障的恢復步驟3.繼續(xù)反向掃描日志文件,查找該事務的其他更新操作,并做同樣處理。4.如此處理下去,直至讀到此事務的開始標記,事務故障恢復就完成了。60例:如圖要對事務Ti進行恢復,

即撤消(UNDO)該事務對數(shù)據(jù)庫的修改步驟如下:(1)從日志文件尾反向掃描,找到Ti-insert記錄,從中知道Ti插入了哪個記錄,將其刪除.(2)再接著往回掃描,找到Ti-update記錄,從中知道Ti修改了哪個記錄,將其用修改前的值替換回去.(3)再接著往回找到Ti-delete記錄,從中知道Ti刪除了哪個記錄,將其插入.(4)再接著往回掃描,找到各個Ti的操作,執(zhí)行UNDO操作直到Ti-begin為止.Ti-begin…Ti-delete…Ti-update…Ti-insert…日志文件尾617.5.2系統(tǒng)故障的恢復系統(tǒng)故障造成數(shù)據(jù)庫不一致狀態(tài)的原因:一些未完成事務對數(shù)據(jù)庫的更新已寫入數(shù)據(jù)庫一些已提交事務對數(shù)據(jù)庫的更新還留在緩沖區(qū)沒來得及寫入數(shù)據(jù)庫恢復方法1.Undo〔撤消〕故障發(fā)生時未完成的事務2.Redo〔重做〕已完成的事務系統(tǒng)故障的恢復由系統(tǒng)在重新啟動時自動完成,不需要用戶干預62系統(tǒng)故障的恢復步驟1. 正向掃描日志文件〔即從前頭掃描日志文件〕將在故障發(fā)生前已經(jīng)提交的事務記入Redo隊列:T1,T3,T8…..(這些事務既有BEGINTRANSACTION記錄,也有COMMIT記錄)將故障發(fā)生時尚未完成的事務記入Undo隊列:T2,T4,T5,T6,T7,T9…...…..(這些事務有BEGINTRANSACTION記錄,無COMMIT記錄)63系統(tǒng)故障的恢復步驟2.對Undo隊列事務進行UNDO(撤消)處理反向掃描日志文件,對每個UNDO事務的更新操作執(zhí)行逆操作:將“更新前的值”寫入數(shù)據(jù)庫。3.對Redo隊列事務進行REDO(重做)處理正向掃描日志文件,對每個REDO事務重新執(zhí)行登記的操作,將“更新后的值”寫入數(shù)據(jù)庫。647.5.3介質(zhì)故障的恢復發(fā)生介質(zhì)故障后,磁盤上的物理數(shù)據(jù)和日志文件被破壞。恢復的方法是:1.重裝數(shù)據(jù)庫,使數(shù)據(jù)庫恢復到一致性狀態(tài)2.重做已完成的事務657.5.3介質(zhì)故障的恢復具體恢復步驟:1.裝入最新的后備數(shù)據(jù)庫副本,使數(shù)據(jù)庫恢復到最近一次轉(zhuǎn)儲時的一致性狀態(tài)。對于靜態(tài)轉(zhuǎn)儲的數(shù)據(jù)庫副本,裝入后數(shù)據(jù)庫即處于一致性狀態(tài)對于動態(tài)轉(zhuǎn)儲的數(shù)據(jù)庫副本,還須同時裝入轉(zhuǎn)儲時刻的日志文件副本,利用與恢復系統(tǒng)故障相同的方法〔即REDO+UNDO〕,才能將數(shù)據(jù)庫恢復到一致性狀態(tài)。66利用靜態(tài)轉(zhuǎn)儲副本將數(shù)據(jù)庫恢復到一致性狀態(tài)

故障發(fā)生點

靜態(tài)轉(zhuǎn)儲

運行事務

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論