老司机91精品网站在线观看-老司机67194免费观看-老司国产精品视频-老熟人老女人国产老太-中文字幕日本在线-中文字幕日本一区久久

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

Oracle 實例恢復時 前滾(roll forward) 后滾(roll back) 問題

發布時間:  2012/8/20 17:18:48

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

一. 什么時候需要實例恢復
       在shutdown normal or shutdown immediate下,也就是所謂的clean shutdown,checkpoint也會自動觸發,并且把SCN紀錄寫回。 當發生checkpoint時,會把SCN寫到四個地方:
 

三個地方于control file內:
(1)SYSTEM CHECKPOINT SCN

(2)Datafile checkpoint SCN

(3)Stop SCN

 

一個在datafile header內:
Start SCN

 

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

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

 

1.2 非正常shutdown

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

 

注意一點:
       (1)啟動數據庫時,如果發現STOP SCN = NULL,表示需要進行crash recovery;
       (2)啟動數據庫時,如果發現有datafile header的START SCN 不等于儲存于CONTROLFILE的DATAFILE SCN,表示需要進行Media recovery

 

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

 

 

二.  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表空間在內。


本文出自:億恩科技【www.ypdoo.com.cn】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    一本伊大人香蕉高清在线观看| 欧美一区二区三区在线观看| 欧美a级片视频| 精品美女| 九九久久国产精品大片| 四虎影视库| 国产精品12| 韩国毛片| 一级片免费在线观看视频| 亚洲精品久久玖玖玖玖| 色综合久久手机在线| 欧美另类videosbestsex| 成人免费观看的视频黄页| 国产麻豆精品| 免费国产一级特黄aa大片在线| 国产91精品系列在线观看| 九九精品久久久久久久久| 国产一区二区精品| 美国一区二区三区| 国产不卡高清在线观看视频| 日本在线www| 欧美1区| 超级乱淫黄漫画免费| 免费一级片网站| 精品视频一区二区三区免费| 成人影院久久久久久影院| 日本免费区| 一级片免费在线观看视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 成人a大片在线观看| 国产亚洲精品aaa大片| 毛片高清| 欧美一级视| 精品视频一区二区| 免费毛片播放| 一本伊大人香蕉高清在线观看| 精品国产香蕉在线播出| 一级毛片视频在线观看| 你懂的日韩| 韩国毛片免费| 国产视频在线免费观看| 精品视频在线观看一区二区三区| 你懂的在线观看视频| 免费一级片在线| 可以免费看毛片的网站| 成人av在线播放| 午夜欧美福利| 黄色短视屏| 毛片的网站| 日本伦理网站| 日本免费区| 亚洲wwwwww| 日本在线不卡免费视频一区| 四虎久久影院| 99久久精品国产片| 精品国产三级a| 久草免费在线视频| 日日日夜夜操| 尤物视频网站在线| 久久精品免视看国产成人2021| 沈樵在线观看福利| 午夜在线影院| 成人在激情在线视频| 国产激情视频在线观看| 欧美激情一区二区三区视频 | 成人免费一级纶理片| 欧美激情影院| 欧美国产日韩久久久| 国产精品12| 国产高清视频免费观看| 午夜欧美福利| 亚洲爆爽| 香蕉视频三级| 国产麻豆精品免费密入口| 精品国产三级a| 国产91精品一区| 国产成a人片在线观看视频| 可以免费看毛片的网站| 日本在线不卡免费视频一区| 九九九在线视频| 成人影院一区二区三区| 在线观看导航| 四虎久久精品国产| 欧美一区二区三区在线观看| 一级毛片视频免费| 国产亚洲免费观看| 青青青草影院 | 欧美a级片免费看| 欧美激情一区二区三区在线播放| 国产一区二区精品| 九九久久99| 韩国三级香港三级日本三级| 国产一区免费观看| 韩国毛片免费| 日本伦理片网站| 日本在线www| 日韩在线观看免费| 黄色免费三级| 欧美1卡一卡二卡三新区| 四虎影视库国产精品一区| 九九热精品免费观看| 国产亚洲精品aaa大片| 日日夜夜婷婷| 日本在线不卡免费视频一区| 九九热国产视频| 国产精品免费久久| 精品国产亚一区二区三区| 日韩一级黄色大片| 国产极品白嫩美女在线观看看| 91麻豆精品国产综合久久久| 黄色福利片| 天天做日日爱| 欧美另类videosbestsex视频| 欧美国产日韩在线| 国产成人女人在线视频观看| 99色视频在线| 韩国三级香港三级日本三级| 欧美一级视频免费| 国产伦精品一区二区三区在线观看 | 日本在线不卡免费视频一区| 日韩专区一区| 国产国语对白一级毛片| 国产a视频| 国产原创中文字幕| 日本特黄特黄aaaaa大片| 精品在线免费播放| 成人免费福利片在线观看| 精品视频在线观看视频免费视频| 成人免费观看网欧美片| 日韩免费片| 久久国产精品永久免费网站| 日韩中文字幕在线播放| 国产不卡福利| 国产不卡精品一区二区三区| 国产亚洲精品aaa大片| a级毛片免费观看网站| 免费国产在线观看| 国产一区二区精品久久91| 欧美大片a一级毛片视频| 91麻豆精品国产片在线观看| 国产成人啪精品| 午夜在线亚洲男人午在线| 欧美激情一区二区三区在线| 日韩免费在线| 国产一区免费观看| 午夜在线亚洲| 国产美女在线观看| 欧美1卡一卡二卡三新区| 国产成a人片在线观看视频| 国产综合成人观看在线| 日韩在线观看视频免费| 99色视频在线| 成人在激情在线视频| 亚洲wwwwww| 国产91精品一区| a级精品九九九大片免费看| 精品视频一区二区三区免费| 韩国三级视频在线观看| 国产一区二区精品久| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美日本免费| 九九热国产视频| 精品视频免费看| 日韩中文字幕一区| 青草国产在线观看| 亚洲爆爽| 黄视频网站免费看| 久久99青青久久99久久| 久久国产精品自由自在| 999精品在线| 日韩一级黄色| 亚洲天堂一区二区三区四区| 天天做人人爱夜夜爽2020| 日韩在线观看免费完整版视频| 欧美另类videosbestsex视频 | 青草国产在线观看| 精品国产一级毛片| 一级片免费在线观看视频| 精品在线观看一区| 精品国产亚一区二区三区| 999精品在线| 午夜在线影院| 黄视频网站在线免费观看| 国产视频网站在线观看| 国产不卡精品一区二区三区| 999精品在线| 精品久久久久久影院免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美激情在线精品video| 中文字幕97| 久久国产影院| 精品久久久久久免费影院| 国产一区免费在线观看| 九九热国产视频| 国产一区二区精品久| 国产a网| 91麻豆国产| 欧美爱爱动态| 欧美另类videosbestsex久久| 香蕉视频三级|