日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Oracle 实例恢复时 前滚(roll forward) 后滚(roll back) 问题

發布時間:2025/6/17 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Oracle 实例恢复时 前滚(roll forward) 后滚(roll back) 问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

?????? ITPUB 論壇上看到一個有關實例恢復時 前滾(roll forword回滾(roll back的討論。在這里小整理一下,也理理自己的一個思路。

?

. 什么時候需要實例恢復

?????? shutdown?normal?or?shutdown?immediate下,也就是所謂的clean?shutdowncheckpoint也會自動觸發,并且把SCN紀錄寫回。?當發生checkpoint時,會把SCN寫到四個地方:

?

三個地方于control?file內:

1SYSTEM?CHECKPOINT?SCN

2Datafile?checkpoint?SCN?

3Stop?SCN

?

一個在datafile?header內:

Start?SCN

?

1.1 Clean shutdown

?????? clean?shutdown?時,checkpoint會進行,并且此時datafilestop?scn和控制文件里的start?scn會相同?等到open數據庫時,Oracle檢查datafile?header中的start?scn和存于control?file中的datafilescn是否相同,?如果相同,接著檢查start?scnstop?scn是否相同,如果仍然相同,數據庫就會正常開啟,否則就需要recovery

?????? 等到數據庫開啟后,儲存在control?file中的stop?scn就會恢復為NULL,此時表示datafileopen在正常模式下了。

?

1.2 非正常shutdown

?????? 如果不正常SHUTDOWN?(shutdown?abort),則mount數據庫后,會發現stop?scn并不是等于其它位置的scn?而是等于NULL這表示Oracleshutdown時沒有進行checkpoint下次開機必須進行crash?recovery(實例恢復)

?

注意一點:

?????? 1)啟動數據庫時,如果發現STOP?SCN?=?NULL表示需要進行crash?recovery

?????? 2)啟動數據庫時,如果發現有datafile?headerSTART?SCN?不等于儲存于CONTROLFILEDATAFILE?SCN表示需要進行Media?recovery

?

1.3 crash?recovery 順序問題

?????? 必須先進行roll?forward(redo?log?file中從目前的start?SCN開始,重做后面的已提交之交易) 再從roll?back?segment?rollback未完成(dead?transaction)交易。檢驗controlfile中的SCN會等于datafile?headerSCN

?

關于這塊內容,具體參考:

?????? RedoLog Checkpoint SCN關系

?????? http://blog.csdn.net/tianlesoftware/archive/2010/01/24/5251916.aspx

?

. ?Crash Recovery 過程

?????? 當數據庫突然崩潰,而還沒有來得及將buffer cache里的臟數據塊刷新到數據文件里,同時在實例崩潰時正在運行著的事務被突然中斷,則事務為中間狀態,也就是既沒有提交也沒有回滾。這時數據文件里的內容不能體現實例崩潰時的狀態。這樣關閉的數據庫是不一致的

?

?????? 下次啟動實例時,Oracle會由SMON進程自動進行實例恢復。實例啟動時,SMON進程會去檢查控制文件中所記錄的、每個在線的、可讀寫的數據文件的END SCN號。

?????? 數據庫正常運行過程中,該END SCN號始終為NULL,而當數據庫正常關閉時,會進行完全檢查點,并將檢查點SCN號更新該字段。

?????? 而崩潰時,Oracle還來不及更新該字段,則該字段仍然為NULL。當SMON進程發現該字段為空時,就知道實例在上次沒有正常關閉,于是由SMON進程就開始進行實例恢復了。

?

?????? SMON進程進行實例恢復時,會從控制文件中獲得檢查點位置。于是,SMON進程到聯機日志文件中,找到該檢查點位置,然后從該檢查點位置開始往下,應用所有的重做條目,從而在buffer cache里又恢復了實例崩潰那個時間點的狀態。這個過程叫做前滾,前滾完畢以后,buffer cache里既有崩潰時已經提交還沒有寫入數據文件的臟數據塊,也還有事務被突然終止,而導致的既沒有提交又沒有回滾的事務所弄臟的數據塊。

?

?????? 前滾一旦完畢,SMON進程立即打開數據庫。但是,這時的數據庫中還含有那些中間狀態的、既沒有提交又沒有回滾的臟塊,這種臟塊是不能存在于數據庫中的,因為它們并沒有被提交,必須被回滾。打開數據庫以后,SMON進程會在后臺進行回滾。

?

?????? 有時,數據庫打開以后,SMON進程還沒來得及回滾這些中間狀態的數據塊時,就有用戶進程發出讀取這些數據塊的請求。這時,服務器進程在將這些塊返回給用戶之前,由服務器進程負責進行回滾,回滾完畢后,將數據塊的內容返回給用戶。

?

?

. 為什么數據庫的實例恢復是先前滾再回滾

?

?????? 回滾段實際上也是以回滾表空間的形式存在的,既然是表空間,那么肯定就有對應的數據文件,同時在buffer cache 中就會存在映像塊,這一點和其他表空間的數據文件相同。

??????

?????? 當發生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表空間的塊也可能因為數據庫故障而丟失為了保障在下一次啟動時能夠順利進行回滾,首先就必須使用REDO日志來恢復UNDO(實際上是先回復Buffer Cache中的臟數據塊,然后由Checkpoint寫入UNDO段中),在數據庫OPEN以后再使用UNDO信息來進行回滾,達到一致性的目的。

?????? 生成完UNDO BLOCK's REDO Entry后才輪到該DML語句對應的REDO Entry,最后再修改Buffer Cache中的Block,該Block同時變為臟數據塊。

?

?????? 實際上,簡單點說REDO的作用就是記錄所有的數據庫更改,包括UNDO表空間在內。

?

?

?

?

?

整理自網絡

---------------------------------------------------------------------------------------------------

Blog http://blog.csdn.net/tianlesoftware

網上資源: http://tianlesoftware.download.csdn.net

相關視頻:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx

DBA1 群:62697716(滿); DBA2 群:62697977(滿) DBA3 群:62697850(滿)??

DBA 超級群:63306533(滿); DBA4 群: 83829929 DBA5群: 142216823

聊天 群:40132017? 聊天2群:69087192

--加群需要在備注說明Oracle表空間和數據文件的關系,否則拒絕申請

轉載于:https://www.cnblogs.com/springside-example/archive/2011/03/29/2529768.html

總結

以上是生活随笔為你收集整理的Oracle 实例恢复时 前滚(roll forward) 后滚(roll back) 问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。