RMAN正確地刪除Archivelog以及設置有備庫的歸檔刪除策略

原文連接:http://blog.sina.com.cn/s/blog_64e166580100xks5.htmlhtml


如何正確地刪除Archivelog:
Archivelog並不能直接得從OS層直接物理刪除,由於archivelog的相關信息是記錄在controlfile中的,當物理刪除後不會改變controlfile的設置。而且在查詢相關的動態視圖(例如v$archived_log)時,該部分日誌仍然標註爲存在。也就是說Oracle並不認爲這些日誌被刪除了,因此在刪除archivelog的時候,須要咱們在其餘地方作一些設置。 


1、使用RMAN清楚物理刪除後的記錄 
可使用RMAN來刪除archivelog,具體能夠按如下步驟操做: 
一、物理刪除archivelog 
二、進入RMAN 
三、crosscheck archivelog all; 
四、delete expired archivelog all; 
這樣就在一些Oracle的記錄中查不到相應的archivelog記錄了。 


2、直接使用RMAN刪除archivelog 
其實在RMAN中是可使用命令直接將ARCHIVELOG刪除的,命令以下: 
RMAN> DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7'; 
表示刪除7天之前的全部archivelog,可是這個命令的缺點是沒法對archivelog進行細緻的劃分。 


3、使用RMAN備份achivelog後刪除 
這是一種最爲穩妥的方法了,使用RMAN備份archivelog,備份後所有刪除 
backup format '/u01/arch_%T_%s_%U' archivelog all delete input; 
或者 
backup database plus archivelog;


注:我在庫上設置了Streams後,使用RMAN刪除archivelog會致使報錯RMAN-08137: WARNING: 
archive log not deleted as it is still needed. 不知道該如何解決,聽說是10.2的一個bug,若是真
是bug的話,那隻能在OS層設置刪除,或用RMAN進行強制刪除了。
10g以後的版本,Oracle在RMAN中內置增長了一項歸檔文件的刪除策略,終於,DBA能夠僅經過一項配置就
解決該問題了。該策略對應兩個值:
APPLIED ON STANDBY:設置爲該值時,當經過附加的DELETE INPUT子句刪除Standby數據庫仍須要的日誌
時,會提示RMAN-08137錯誤。不過用戶仍然能夠手動地經過DELETE ARCHIVELOG方式刪除。
NONE:設置爲該值時,則不啓用歸檔文件的刪除策略。默認狀況下就是NONE。
例如,啓用APPLIED ON STANDBY:
RMAN> CONFIGURE ARCHIVELOG DELETION POLICY TO APPLIED ON STANDBY; 
new RMAN configuration parameters: 
CONFIGURE ARCHIVELOG DELETION POLICY TO APPLIED ON STANDBY; 
new RMAN configuration parameters are successfully stored 
RMAN> run
{
backup archivelog all delete input format 'ZHSVR044_%d_set=%s_piece=%p_date=%T.ARC.rmn';
}


都知道在controlfile中記錄着每個archivelog的相關信息,固然們在OS下把這些物理文件delete掉後,在咱們的
controlfile中仍然記錄着這些archivelog的信息,在oracle的OEM管理器中有可視化的日誌展示出,當咱們手工清除archive目錄下的文件後,這些記錄並無被咱們從controlfile中清除掉,也就是oracle並不知道這些文件已經不存在了!這時候咱們要作手工的清除的話,下面我通過實驗,能夠嘗試這種方法:
1. 進入rman  
2. connect target /
3. crosscheck archivelog all;
4. delete expired archivelog all;
這時候咱們再去OEM中看就必定看不到,若是你的歷來沒有作過這個動做的話,咱們能夠比較從這個動做前的controlfile後動做後的controlfile的大小!


ORACLE正確刪除歸檔並回收空間的方法
ORACLE正確刪除歸檔並回收空間的方法
一個ORACLE歸檔日誌常常滿,表現爲/oraarchive 這個文件空間佔用100%你們必定抱怨ORACLE爲什麼沒有歸檔維護工具,不少人直接刪除了事,錯了,ORACLE有,並且很智能,能夠正確的刪除歸檔和FLASHBACK,不過切記,ORACLE歸檔日誌對於ORACLE的數據恢復和備份很是重要,不到萬不得已不要刪除歸檔日誌。
刪除歸檔日誌的過程
以ORACLE用戶身份登陸到數據庫服務器主機或經過網絡鏈接
進入ORACLE數據備份工具
rman target/
或rman target/@orcl
在命令窗口裏面執行
DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';
說明
SYSDATA-7,代表當前的系統時間7天前,before關鍵字表示在7天前的歸檔日誌,若是使用了閃回功能,也會刪除閃回的數據。
一樣道理,也能夠刪除從7天前到如今的所有日誌,不過這個命令要考慮清楚,作完這個刪除,最好立刻進行全備份數據庫
DELETE ARCHIVELOG FROM TIME 'SYSDATE-7';


UNIX/LINUX下也能夠經過FIND找到7天前的歸檔數據,使用EXEC子操做刪除


find /oraarchive -xdev -mtime +7 -name "*.dbf" -exec rm -f {} ;
這樣作仍然會在RMAN裏留下未管理的歸檔文件
仍須要在RMAN裏執行下面2條命令
crosscheck archivelog all;
delete expired archivelog all;
因此還不如上面的方法好用,不過用FIND的好處就是,能夠在條件上,和EXEC子項上作不少操做,實現更復雜的功能
3.簡要介紹一下report obsolete命令
使用report obsolete命令報告過時備份
RMAN> report obsolete;
RMAN retention policy will be applied to the command
RMAN retention policy is set to redundancy 1
Report of obsolete backups and copies
Type                 Key    Completion Time    Filename/Handle
-------------------- ------ ------------------ --------------------
Backup Set           125    01-NOV-04
Backup Piece       125    01-NOV-04          /data1/oracle/orabak/full_1_541045804
Backup Set           131    04-NOV-04
Backup Piece       131    04-NOV-04          /data1/oracle/orabak/full_AVATAR2_20041104_131
....
Backup Set           173    06-DEC-04
Backup Piece       173    06-DEC-04          /data1/oracle/orabak/full_AVATAR2_20041206_173
Backup Set           179    11-DEC-04
Backup Piece       179    11-DEC-04          /data1/oracle/orabak/arch544588206.arc
.....
Backup Piece       189    17-DEC-04          /data1/oracle/orabak/arch545106606.arc
Backup Set           190    17-DEC-04
Backup Piece       190    17-DEC-04          /data1/oracle/orabak/arch545106665.arc
Backup Set           191    20-DEC-04
Backup Piece       191    20-DEC-04          /data1/oracle/orabak/arch_AVATAR2_20041220_194
Archive Log          2973   20-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2985.dbf
Archive Log          2971   20-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2984.dbf
.....
Archive Log          2705   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2717.dbf
Archive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbf
Archive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbf
Archive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbf
4.使用delete obsolete命令刪除過時備份:
RMAN> delete obsolete;
RMAN retention policy will be applied to the command
RMAN retention policy is set to redundancy 1
using channel ORA_DISK_1
Deleting the following obsolete backups and copies:
Type                 Key    Completion Time    Filename/Handle
-------------------- ------ ------------------ --------------------
Backup Set           125    01-NOV-04
Backup Piece       125    01-NOV-04          /data1/oracle/orabak/full_1_541045804
....
Archive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbf
Archive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbf
Archive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbf
Do you really want to delete the above objects (enter YES or NO)? yes
deleted backup piece
backup piece handle=/data1/oracle/orabak/full_AVATAR2_20041206_173 recid=173 stamp=544156241
.....
deleted archive log
archive log filename=/opt/oracle/oradata/avatar2/archive/1_2715.dbf recid=2703 stamp=545108268
deleted archive log
archive log filename=/opt/oracle/oradata/avatar2/archive/1_2714.dbf recid=2702 stamp=545107659
Deleted 286 objects


RMAN> crosscheck archivelog all;
released channel: ORA_DISK_1
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=19 devtype=DISK
specification does not match any archive log in the recovery catalog


5 在rman中用crosscheck檢查歸檔日誌,2個歸檔日誌都是失敗的:
RMAN> crosscheck archivelog all;
釋放的通道: ORA_DISK_1
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=14 devtype=DISK
對歸檔日誌的驗證失敗
存檔日誌文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 記錄 ID=1 時間戳 =572866
683
對歸檔日誌的驗證失敗
存檔日誌文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 記錄 ID=2 時間戳 =57286
6931
已交叉檢驗的 2 對象
6 試着同步一下,看行不行,結果不行,crosscheck仍是失敗:
RMAN> resync catalog;
正在啓動所有恢復目錄的 resync
完成所有 resync
RMAN> crosscheck archivelog all;
釋放的通道: ORA_DISK_1
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=14 devtype=DISK
對歸檔日誌的驗證失敗
存檔日誌文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 記錄 ID=1 時間戳 =572866
683
對歸檔日誌的驗證失敗
存檔日誌文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 記錄 ID=2 時間戳 =57286
6931
已交叉檢驗的 2 對象
7 用list expired看看是否有失效的archive log,證實沒有失效的archive log:
RMAN> list expired archivelog all;
說明與恢復目錄中的任何存檔日誌均不匹配
8 更改語言環境試試,結果再次crosscheck,2個archive log 都成功了:
RMAN> exit


恢復管理器完成。
C:>set nls_lang=american_america.zhs16gbk
C:>rman catalogrman/rman@safetarget /
Recovery Manager: Release 9.2.0.1.0 - Production
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
connected to target database: TEST (DBID=1870953724)
connected to recovery catalog database
RMAN> crosscheck archivelog all;
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=9 devtype=DISK
validation succeeded for archived log
archive log filename=D:ORACLEORADATATESTARCHIVE1_47.DBF recid=1 stamp=57286
6683
validation succeeded for archived log
archive log filename=D:ORACLEORADATATESTARCHIVE11_48.DBF recid=2 stamp=5728
66931
Crosschecked 2 objects


刪除N天之前的歸檔日誌,有兩個命令:
delete archivelog until time 'sysdate-N'
delete archivelog all completed before 'sysdate-N'
 
看下二者的區別:
RMAN> list archivelog until time 'sysdate-1';
List of Archived Log Copies
Key     Thrd Seq     S Low Time   Name
------- ---- ------- - ---------- ----
7       1    5       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_13/thread_1_seq_5.259.756405771
10      1    6       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_6.263.756453607
16      1    7       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_7.268.756467343
17      1    8       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_8.269.756467345
18      1    9       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_9.270.756467399
19      1    10      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_10.271.756467403
21      1    11      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_11.272.756467511
22      1    12      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_12.274.756467515
23      1    13      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_13.275.756467521
25      1    14      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_14.276.756467527
26      1    15      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_15.278.756467635
27      1    16      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_16.279.756484801
29      1    17      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_15/thread_1_seq_17.256.756576859
5       2    2       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_13/thread_2_seq_2.257.756405175
8       2    3       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_3.260.756442807
9       2    4       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_4.261.756442823
11      2    5       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_5.262.756453607
12      2    6       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_6.264.756453623
13      2    7       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_7.265.756467273
14      2    8       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_8.266.756467279
15      2    9       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_9.267.756467279
20      2    10      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_10.273.756467511
24      2    11      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_11.277.756467533
28      2    12      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_15/thread_2_seq_12.280.756566433
最大sequence爲17和12
再看:
RMAN> list archivelog all completed before 'sysdate-1';


List of Archived Log Copies
Key     Thrd Seq     S Low Time   Name
------- ---- ------- - ---------- ----
7       1    5       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_13/thread_1_seq_5.259.756405771
10      1    6       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_6.263.756453607
16      1    7       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_7.268.756467343
17      1    8       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_8.269.756467345
18      1    9       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_9.270.756467399
19      1    10      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_10.271.756467403
21      1    11      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_11.272.756467511
22      1    12      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_12.274.756467515
23      1    13      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_13.275.756467521
25      1    14      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_14.276.756467527
26      1    15      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_15.278.756467635
27      1    16      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_1_seq_16.279.756484801
5       2    2       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_13/thread_2_seq_2.257.756405175
8       2    3       A 13-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_3.260.756442807
9       2    4       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_4.261.756442823
11      2    5       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_5.262.756453607
12      2    6       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_6.264.756453623
13      2    7       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_7.265.756467273
14      2    8       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_8.266.756467279
15      2    9       A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_9.267.756467279
20      2    10      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_10.273.756467511
24      2    11      A 14-7月 -11 +RECOVERY/edu/archivelog/2011_07_14/thread_2_seq_11.277.756467533
 
詳細看下 這些日誌的區別:
QL> select THREAD#,sequence#,FIRST_TIME,NEXT_TIME,COMPLETION_TIME  
  2  from v$archived_log order by thread#,sequence#;
   THREAD#  SEQUENCE# FIRST_TIME        NEXT_TIME         COMPLETION_TIME
---------- ---------- ----------------- ----------------- -----------------
         1          1 20110713 14:57:58 20110713 14:58:42 20110713 14:58:49
         1          2 20110713 14:58:42 20110713 14:59:00 20110713 14:59:18
         1          3 20110713 14:59:00 20110713 15:02:31 20110713 15:02:36
         1          4 20110713 15:02:31 20110713 16:32:50 20110713 16:32:57
         1          5 20110713 16:32:50 20110713 16:41:40 20110713 16:42:51
         1          6 20110713 16:41:40 20110714 06:00:07 20110714 06:00:08
         1          7 20110714 06:00:07 20110714 09:26:57 20110714 09:49:04
         1          8 20110714 09:26:57 20110714 09:46:55 20110714 09:49:04
         1          9 20110714 09:46:55 20110714 09:49:58 20110714 09:50:06
         1         10 20110714 09:49:58 20110714 09:50:02 20110714 09:50:09
         1         11 20110714 09:50:02 20110714 09:51:49 20110714 09:51:59
   THREAD#  SEQUENCE# FIRST_TIME        NEXT_TIME         COMPLETION_TIME
---------- ---------- ----------------- ----------------- -----------------
         1         12 20110714 09:51:49 20110714 09:51:55 20110714 09:52:05
         1         13 20110714 09:51:55 20110714 09:52:01 20110714 09:52:10
         1         14 20110714 09:52:01 20110714 09:52:07 20110714 09:52:13
         1         15 20110714 09:52:07 20110714 09:53:54 20110714 09:53:59
         1         16 20110714 09:53:54 20110714 14:40:01 20110714 14:40:05
         1         17 20110714 14:40:01 20110715 16:14:19 20110715 16:14:20
         1         18 20110715 16:14:19 20110715 16:15:46 20110715 16:15:47
         2          1 20110713 15:14:43 20110713 16:15:41 20110713 16:17:14
         2          2 20110713 16:15:41 20110713 16:32:50 20110713 16:32:54
         2          3 20110713 16:32:50 20110714 03:00:07 20110714 03:00:12
         2          4 20110714 03:00:07 20110714 03:00:23 20110714 03:00:27
   THREAD#  SEQUENCE# FIRST_TIME        NEXT_TIME         COMPLETION_TIME
---------- ---------- ----------------- ----------------- -----------------
         2          5 20110714 03:00:23 20110714 06:00:06 20110714 06:00:11
         2          6 20110714 06:00:06 20110714 06:00:22 20110714 06:00:27
         2          7 20110714 06:00:22 20110714 06:00:37 20110714 09:47:56
         2          8 20110714 06:00:37 20110714 09:26:56 20110714 09:48:05
         2          9 20110714 09:26:56 20110714 09:47:56 20110714 09:48:05
         2         10 20110714 09:47:56 20110714 09:51:51 20110714 09:51:52
         2         11 20110714 09:51:51 20110714 09:52:12 20110714 09:52:12
         2         12 20110714 09:52:12 20110715 13:20:33 20110715 13:20:37
區別已經很明顯:
 list archivelog until time 'sysdate-1'; 此時是按照歸檔日誌開始時間即fisrt_time做爲截止時間
 list archivelog all completed before 'sysdate-1' 是按照歸檔日誌完成時間即completion_time做爲截止時間
試想若是刪除歸檔日誌,仍是採用delete archivelog all completed before 'sysdate-N'

數據庫

相關文章
相關標籤/搜索