Oracle 實例恢復時 前滾(roll forward) 后滾(roll back) 問題 |
發(fā)布時間: 2012/8/20 17:18:48 |
看到一個有關實例恢復時 前滾(roll forword)和回滾(roll back)的討論。在這里小整理一下,也理理自己的一個思路。 一. 什么時候需要實例恢復 三個地方于control file內: (2)Datafile checkpoint SCN (3)Stop SCN
一個在datafile header內:
1.1 Clean shutdown 時 等到數(shù)據(jù)庫開啟后,儲存在control file中的stop scn就會恢復為NULL值,此時表示datafile是open在正常模式下了。
1.2 非正常shutdown 如果不正常SHUTDOWN (shutdown abort),則mount數(shù)據(jù)庫后,會發(fā)現(xiàn)stop scn并不是等于其它位置的scn, 而是等于NULL,這表示Oracle在shutdown時沒有進行checkpoint,下次開機必須進行crash recovery(實例恢復)。
注意一點:
1.3 crash recovery 順序問題
二. Crash Recovery 過程
下次啟動實例時,Oracle會由SMON進程自動進行實例恢復。實例啟動時,SMON進程會去檢查控制文件中所記錄的、每個在線的、可讀寫的數(shù)據(jù)文件的END SCN號。 數(shù)據(jù)庫正常運行過程中,該END SCN號始終為NULL,而當數(shù)據(jù)庫正常關閉時,會進行完全檢查點,并將檢查點SCN號更新該字段。 而崩潰時,Oracle還來不及更新該字段,則該字段仍然為NULL。當SMON進程發(fā)現(xiàn)該字段為空時,就知道實例在上次沒有正常關閉,于是由SMON進程就開始進行實例恢復了。
SMON進程進行實例恢復時,會從控制文件中獲得檢查點位置。于是,SMON進程到聯(lián)機日志文件中,找到該檢查點位置,然后從該檢查點位置開始往下,應用所有的重做條目,從而在buffer cache里又恢復了實例崩潰那個時間點的狀態(tài)。這個過程叫做前滾,前滾完畢以后,buffer cache里既有崩潰時已經(jīng)提交還沒有寫入數(shù)據(jù)文件的臟數(shù)據(jù)塊,也還有事務被突然終止,而導致的既沒有提交又沒有回滾的事務所弄臟的數(shù)據(jù)塊。
前滾一旦完畢,SMON進程立即打開數(shù)據(jù)庫。但是,這時的數(shù)據(jù)庫中還含有那些中間狀態(tài)的、既沒有提交又沒有回滾的臟塊,這種臟塊是不能存在于數(shù)據(jù)庫中的,因為它們并沒有被提交,必須被回滾。打開數(shù)據(jù)庫以后,SMON進程會在后臺進行回滾。 有時,數(shù)據(jù)庫打開以后,SMON進程還沒來得及回滾這些中間狀態(tài)的數(shù)據(jù)塊時,就有用戶進程發(fā)出讀取這些數(shù)據(jù)塊的請求。這時,服務器進程在將這些塊返回給用戶之前,由服務器進程負責進行回滾,回滾完畢后,將數(shù)據(jù)塊的內容返回給用戶。
三. 為什么數(shù)據(jù)庫的實例恢復是先前滾再回滾 回滾段實際上也是以回滾表空間的形式存在的,既然是表空間,那么肯定就有對應的數(shù)據(jù)文件,同時在buffer cache 中就會存在映像塊,這一點和其他表空間的數(shù)據(jù)文件相同。
當發(fā)生DML操作時,既要生成REDO(針對DML操作本身的REDO Entry)也要生成UNDO(用于回滾該DML操作,記錄在UNDO表空間中),但是既然UNDO信息也是使用回滾表空間來存放的,那么該DML操作對應的UNDO信息(在BUFFER CACHE生成對應中的UNDO BLOCK)就會首先生成其對應的REDO信息(UNDO BLOCK's REDO Entry)并寫入Log Buffer中。
這樣做的原因是因為Buffer Cache中的有關UNDO表空間的塊也可能因為數(shù)據(jù)庫故障而丟失,為了保障在下一次啟動時能夠順利進行回滾,首先就必須使用REDO日志來恢復UNDO段(實際上是先回復Buffer Cache中的臟數(shù)據(jù)塊,然后由Checkpoint寫入UNDO段中),在數(shù)據(jù)庫OPEN以后再使用UNDO信息來進行回滾,達到一致性的目的。 生成完UNDO BLOCK's REDO Entry后才輪到該DML語句對應的REDO Entry,最后再修改Buffer Cache中的Block,該Block同時變?yōu)榕K數(shù)據(jù)塊。
實際上,簡單點說REDO的作用就是記錄所有的數(shù)據(jù)庫更改,包括UNDO表空間在內。 本文出自:億恩科技【mszdt.com】 |