資源描述:
《oracle 數(shù)據(jù)庫恢復實例》由會員上傳分享,免費在線閱讀,更多相關內(nèi)容在行業(yè)資料-天天文庫。
1、Oracle數(shù)據(jù)庫恢復實例一理解什么是數(shù)據(jù)庫恢復當我們使用一個數(shù)據(jù)庫時,總希望數(shù)據(jù)庫的內(nèi)容是可靠的、正確的,但由于計算機系統(tǒng)的故障(硬件故障、軟件故障、網(wǎng)絡故障、進程故障和系統(tǒng)故障)影響數(shù)據(jù)庫系統(tǒng)的操作,影響數(shù)據(jù)庫中數(shù)據(jù)的正確性,甚至破壞數(shù)據(jù)庫,使數(shù)據(jù)庫中全部或部分數(shù)據(jù)丟失。因此當發(fā)生上述故障后,希望能重構這個完整的數(shù)據(jù)庫,該處理稱為數(shù)據(jù)庫恢復?;謴瓦^程大致可以分為復原(Restore)與恢復(Recover)過程。數(shù)據(jù)庫恢復可以分為以下兩類:1.1實例故障的一致性恢復當實例意外地(如掉電、后臺進程故障等)或預料地(發(fā)出SHUTDO
2、UMABORT語句)中止時出現(xiàn)實例故障,此時需要實例恢復。實例恢復將數(shù)據(jù)庫恢復到故障之前的事務一致狀態(tài)。如果在在線后備發(fā)現(xiàn)實例故障,則需介質(zhì)恢復。在其它情況Oracle在下次數(shù)據(jù)庫起動時(對新實例裝配和打開),自動地執(zhí)行實例恢復。如果需要,從裝配狀態(tài)變?yōu)榇蜷_狀態(tài),自動地激發(fā)實例恢復,由下列處理: (1)為了解恢復數(shù)據(jù)文件中沒有記錄的數(shù)據(jù),進行向前滾。該數(shù)據(jù)記錄在在線日志,包括對回滾段的內(nèi)容恢復。 ?。?)回滾未提交的事務,按步1重新生成回滾段所指定的操作?! 。?)釋放在故障時正在處理事務所持有的資源?! 。?)解決在故障時正經(jīng)歷
3、一階段提交的任何懸而未決的分布事務。1.2介質(zhì)故障或文件錯誤的不一致恢復介質(zhì)故障是當一個文件、一個文件的部分或磁盤不能讀或不能寫時出現(xiàn)的故障。文件錯誤一般指意外的錯誤導致文件被刪除或意外事故導致文件的不一致。這種狀態(tài)下的數(shù)據(jù)庫都是不一致的,需要DBA手工來進行數(shù)據(jù)庫的恢復,這種恢復有兩種形式,決定于數(shù)據(jù)庫運行的歸檔方式和備份方式。(1)完全介質(zhì)恢復可恢復全部丟失的修改。一般情況下需要有數(shù)據(jù)庫的備份且數(shù)據(jù)庫運行在歸檔狀態(tài)下并且有可用歸檔日志時才可能。對于不同類型的錯誤,有不同類型的完全恢復可使用,其決定于毀壞文件和數(shù)據(jù)庫的可用性。(2
4、)不完全介質(zhì)恢復是在完全介質(zhì)恢復不可能或不要求時進行的介質(zhì)恢復。重構受損的數(shù)據(jù)庫,使其恢復介質(zhì)故障前或用戶出錯之前的一個事務一致性狀態(tài)。不完全介質(zhì)恢復有不同類型的使用,決定于需要不完全介質(zhì)恢復的情況,有下列類型:基于撤消、基于時間和基于修改的不完全恢復?! 』诔废?CANCEL)恢復:在某種情況,不完全介質(zhì)恢復必須被控制,DBA可撤消在指定點的操作?;诔废幕謴偷卦谝粋€或多個日志組(在線的或歸檔的)已被介質(zhì)故障所破壞,不能用于恢復過程時使用,所以介質(zhì)恢復必須控制,以致在使用最近的、未損的日志組于數(shù)據(jù)文件后中止恢復操作。 基于時
5、間(TIME)和基于修改(SCN)的恢復:如果DBA希望恢復到過去的某個指定點,是一種理想的不完全介質(zhì)恢復,一般發(fā)生在恢復到某個特定操作之前,恢復到如意外刪除某個數(shù)據(jù)表之前。第二章.數(shù)據(jù)庫恢復案例測試環(huán)境2.1數(shù)據(jù)庫環(huán)境以下的所有案例都是通過測試經(jīng)過,環(huán)境為:OS:Windows2000ServerDB:Oracle816DBNAME:TEST數(shù)據(jù)文件:SQL>selectfile#,status,enabled,namefromv$datafile;FILE#STATUSENABLEDNAME-------------------
6、---------------------------------------------1SYSTEMREADWRITED:OracleORADATATESTSYSTEM01.DBF2ONLINEREADWRITED:OracleORADATATESTRBS01.DBF3ONLINEREADWRITED:OracleORADATATESTUSERS01.DBF4ONLINEREADWRITED:OracleORADATATESTTEMP01.DBF5ONLINEREADWRITED:Oracle
7、ORADATATESTTOOLS01.DBF6ONLINEREADWRITED:OracleORADATATESTINDX01.DBF控制文件:SQL>select*fromv$controlfile;STATUSNAME---------------------------------------------------------------------D:OracleORADATATESTCONTROL01.CTLD:OracleORADATATESTCONTROL02.CTLD:OracleO
8、RADATATESTCONTROL03.CTL聯(lián)機日志:SQL>select*fromv$logfile;GROUP#STATUSMEMBER--------------------------------------------