Oracle 正確刪除歸檔日志的方法


 

       我們都知道在controlfile中記錄着每一個archivelog文件的相關信息,當然們在OS下把這些物理文件delete掉后,在我們的controlfile中仍然記錄着這些archivelog文件的相關信息,在oracle的OEM管理器中有可視化的日志展現出,當我們手工清除 archive目錄下的文件后,這些記錄並沒有被我們從controlfile中清除掉,也就是oracle並不知道這些文件已經不存在了,這時候我們要做手工的清除的話,下面我經過實驗,可以嘗試這種方法:

1、進入rman

[root@db1 ~]# su - oracle [oracle@db1 ~]$ /u01/app/oracle/product/10.2.0/db/bin/rman

一般都設置了環境變量,所以可以直接執行 rman 命令,如下:

[oracle@db1 ~]$ rman Recovery Manager: Release 11.2.0.1.0 - Production on Fri Sep 25 16:18:03 2020 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. RMAN> 

 

2、connect target /

RMAN> connect target / connected to target database: ORA11G (DBID=4206582437)
RMAN
>

 

3、crosscheck archivelog all;

       crosscheck archivelog all:驗證的是DB的歸檔日志即log_archive_dest參數指定位置的文件,當手工刪除了歸檔日志以后,Rman備份會檢測到日志缺失,從而無法進一步繼續執行Rman備份,所以此時需要手工執行crosscheck過程,查看所有的歸檔日志文件是否都是正常的然后再來執行Rman備份。

 

 4、delete expired archivelog all;

       這時候我們再去OEM中就看不到這些日志文件了,如果你的從來沒有做過這個動作的話,我們可以比較這個動作前的controlfile和動作后的controlfile的文件大小。

 

 

Oracle 正確刪除歸檔並回收空間的方法

        一個 Oracle 歸檔日志經常滿,表現為 /archivelog 這個文件空間占用 100%。大家總是抱怨 Oracle 為何沒有歸檔維護工具,很多人直接刪除了事,其實錯了,Oracle有歸檔維護工具,而且很智能,可以正確的刪除歸檔和 FlashBack。

        不過切記:Oracle歸檔日志對於Oracle的數據恢復和備份非常重要,不到萬不得已不要刪除歸檔日志。

        刪除歸檔日志的過程,如下:

 1、以 oracle 用戶身份登錄

       以 oracle 用戶身份登錄到數據庫服務器主機或者通過網絡連接。

2、進入Oracle數據備份工具

[oracle@db ~]# rman RMAN> rman target /

或者

/u01/app/oracle/product/10.2.0/db/bin/rman target/

或者

/u01/app/oracle/product/10.2.0/db/bin/rman target/@DTHXRAC1

3、在RMAN命令窗口里操作

RMAN> DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';

       說明:SYSDATE-7 ,表明當前的系統時間 7天前。before 關鍵字表示在7天前的歸檔日志,如果使用了閃回功能,也會刪除閃回的數據。

       同理,有可以刪除從7天前到現在的全部日志,不過這個命令要考慮清楚,做完這個刪除,最好馬上進行數據庫全備份。       

RMAN> DELETE ARCHIVELOG FROM TIME 'SYSDATE-7';

       Unix/Linux 下也可以通過 find 命令找到7天前的歸檔數據,使用 exec 子操作刪除,如下:

find /archivelog -xdev -mtime +7 -name "*.dbf" -exec rm -f {} \;

       這樣做仍然會在 RMAN 里留下未管理的歸檔文件,它的作用還是相當於直接用操作系統命令將歸檔日志文件直接刪除,而 Oracle 控制文件並不知道,因此仍需要在 RMAN 里執行下面兩條命令:

RMAN> crosscheck archivelog all; RMAN> delete expired archivelog all;

       所以,還不如上面的方法好用,不過用 find 命令的好處就是,可以在條件上和 exec 子項做很多操作,實現更復雜的功能。

 

簡單介紹一下 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

 

使用 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;
allocated channel: ORA_DISK_1
 
channel ORA_DISK_1: sid=9 devtype=DISK
validation succeeded for archived log
archive log filename=/archivelog1/1_615_737652750.dbf recid=928 stamp=750848535
validation succeeded for archived log
archive log filename=/archivelog1/1_616_737652750.dbf recid=930 stamp=750851615
Crosschecked 2 objects

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM