--串連復原管理員
C:\Documents and Settings\mengzhaoliang>rman target/
--歸檔日誌列表
RMAN> list archivelog all;
--刪除物理檔案不存在的歸檔日誌
RMAN> delete expired archivelog all;
--刪除7天前的歸檔日誌
RMAN> DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';
oracle的歸檔模式
一。查看oracle資料庫是否為歸檔模式:
1.select name,log_mode from v$database;
NAME LOG_MODE
------------------ ------------------------
QUERY NOARCHIVELOG
2.使用ARCHIVE LOG LIST 命令
Database log mode No Archive Mode
Automatic archival Disabled
Archive destination /data/oracle/product/10.2.0/db_1//dbs/arch
Oldest online log sequence 739
Current log sequence 741
二。什麼是Oracle歸檔模式?
Oracle資料庫有聯機重做日誌,這個日誌是記錄對資料庫所做的修改,比如插入,刪除,更新資料等,對這些操作都會記錄在聯機重做日誌裡。一般資料庫至少要有2個聯機重做日誌組。當一個聯機重做日誌組被寫滿的時候,就會發生日誌切換,這時聯機重做日誌組2成為當前使用的日誌,當聯機重做日誌組2寫滿的時候,又會發生日誌切換,去寫聯機重做日誌組1,就這樣反覆進行。
如果資料庫處於非歸檔模式,聯機日誌在切換時就會丟棄. 而在歸檔模式下,當發生日誌切換的時候,被切換的日誌會進行歸檔。比如,當前在使用聯機重做日誌1,當1寫滿的時候,發生日誌切換,開始寫聯機重做日誌 2,這時聯機重做日誌1的內容會被拷貝到另外一個指定的目錄下。這個目錄叫做歸檔目錄,拷貝的檔案叫歸檔重做日誌。
資料庫使用歸檔方式運行時才可以進行災難性恢複。
1.歸檔記錄模式和非歸檔記錄模式的區別
非歸檔模式只能做冷備份,並且恢複時只能做完全備份.最近一次完全備份到系統出錯期間的資料不能恢複.
歸檔模式可以做熱備份,並且可以做增量備份,可以做部分恢複.
用ARCHIVE LOG LIST 可以查看期模式狀態時歸檔模式還是非歸檔模式.
三。設定資料庫的歸檔模式
改變非歸檔模式到歸檔模式:
1)SQL>SHUTDOWN NORMAL/IMMEDIATE;
2)SQL>START MOUNT;
3)SQL>ALTER DATABASE ARCHIVELOG;
4)SQL>ALTER DATABASE OPEN;
5)SQL>做一次完全備份,因為非歸檔記錄模式下產生的備份日誌對于歸檔模式已經不可用了.這一步非非常重要!
改變歸檔模式到非歸檔模式:
1)SQL>SHUTDOWN NORMAL/IMMEDIATE;
2)SQL>START MOUNT;
3)SQL>ALTER DATABASE NOARCHIVELOG;
4)SQL>ALTER DATABASE OPEN;
3.啟用自動歸檔: LOG_ARCHIVE_START=TRUE
歸檔模式下,記錄檔組不允許被覆蓋(重寫),當記錄檔寫滿之後,如果沒有進行手動歸檔,那麼系統將掛起,知道歸檔完成為止.
這時只能讀而不能寫.
運行過程中關閉和重啟歸檔日誌進程
SQL>ARCHIVE LOG STOP
SQL>ARCHIVE LOG START
4.手動歸檔: LOG_ARCHIVE_START=FALSE
歸檔當前記錄檔
SQL>ALTER SYSTEM ARCHIVE LOG CURRENT;
歸檔序號為052的記錄檔
SQL>ALTER SYSTEM ARCHIVE LOG SEQUENCE 052;
歸檔所有記錄檔
SQL>ALTER SYSTEM ARCHIVE LOG ALL;
改變歸檔日誌目標
SQL>ALTER SYSTEM ARCHIVE LOG CURRENT TO '&PATH