Oracle數(shù)據(jù)庫(kù)Redo故障的恢復(fù)
Oracle數(shù)據(jù)庫(kù)功能性很好,應(yīng)用也很廣泛,在進(jìn)行Oracle數(shù)據(jù)庫(kù)的操作時(shí)難免會(huì)出現(xiàn)一些故障,本文主要為大家介紹Oracle數(shù)據(jù)庫(kù)Redo故障的恢復(fù)。
一.丟失inactive日志文件組的恢復(fù):
由于inactive日志文件組表示已經(jīng)完成了檢查點(diǎn)(dirty數(shù)據(jù)已經(jīng)被寫(xiě)入數(shù)據(jù)文件)。數(shù)據(jù)庫(kù)本身不會(huì)發(fā)生數(shù)據(jù)庫(kù)丟失,如果在這個(gè)時(shí)候相應(yīng)的redo丟失/損壞,可以通過(guò)clear重建日志文件組恢復(fù)。
通過(guò)命令:
alter database clear logfile group n
如果數(shù)據(jù)庫(kù)模式是archived的,則需要強(qiáng)制清除
alter database clear unarchived logfile group n
二.丟失active或current日志文件組的恢復(fù):
丟失情況分兩種:
一個(gè)是正常關(guān)閉數(shù)據(jù)庫(kù)(如shutdown immediate)
另一個(gè)是異常關(guān)閉數(shù)據(jù)庫(kù)(如shutdown abort)
1.在損失當(dāng)前日志時(shí),數(shù)據(jù)庫(kù)是正常關(guān)閉狀態(tài)。
由于shutdown immediate會(huì)執(zhí)行全面的checkpoint,所以當(dāng)前日志在實(shí)例恢復(fù)時(shí)可以不需要redo
在Oracle 8i中我們完全可以通過(guò)alter database clear logfile group n來(lái)進(jìn)行恢復(fù).
但是在Oracle 9i中,則可能無(wú)法對(duì)current的redo日志進(jìn)行clear,需要通過(guò)recoverdatabaseuntil cancel恢復(fù)后(必須要做的)
用resetlogs選項(xiàng)打開(kāi)。
比如:
alter database clear logfile group n
recover database until cancel;
alter database open resetlogs;
2.在損失當(dāng)前日志時(shí),數(shù)據(jù)庫(kù)是異常關(guān)閉的:
這種情況下,由于沒(méi)有在執(zhí)行全面檢查點(diǎn)時(shí),數(shù)據(jù)庫(kù)就已經(jīng)關(guān)閉了,那么Oracle在進(jìn)行實(shí)例恢復(fù)的時(shí)候必須要求當(dāng)前的日志,否則Oracle數(shù)據(jù)庫(kù)將無(wú)法open.
這樣的情況下,我們通常需要從備份中恢復(fù)數(shù)據(jù)文件,通過(guò)應(yīng)用歸檔日志進(jìn)行向前推演。直到***一個(gè)完好的日志文件,然后可以通過(guò)resetlogs啟動(dòng)數(shù)據(jù)庫(kù)完成恢復(fù)。那么丟失的數(shù)據(jù)則是被損壞的日志文件中的數(shù)據(jù)。
注意:_allow_resetlogs_corruption是Oracle中的一個(gè)隱含參數(shù),如果系統(tǒng)實(shí)在不能resetlogs方式打開(kāi)的后只能出此下策,在pfile進(jìn)行相應(yīng)設(shè)置打開(kāi)數(shù)據(jù)庫(kù)。該函數(shù)的含義是,允許在破壞一致性的情況下強(qiáng)制重置日志,打開(kāi)數(shù)據(jù)庫(kù)。_allow_resetlogs_corruption將使用所有數(shù)據(jù)文件最舊的SCN打開(kāi)數(shù)據(jù)庫(kù),所以通常來(lái)講需要保證SYSTEM表空間擁有最舊的SCN。在強(qiáng)制打開(kāi)數(shù)據(jù)庫(kù)之后,可能因?yàn)楦鞣N原因會(huì)有ora-600。
上文介紹的知識(shí)Oracle數(shù)據(jù)庫(kù)Redo故障恢復(fù)的部分方法,如果大家知道更好更有效的恢復(fù)方法,歡迎與大家分享。
【編輯推薦】
- Oracle數(shù)據(jù)庫(kù)索引創(chuàng)建要做到三個(gè)適當(dāng)
- 如何將Oracle數(shù)據(jù)庫(kù)的普通表轉(zhuǎn)換成分區(qū)表
- 講解Oracle數(shù)據(jù)庫(kù)提供的多種安全性措施