如何正确删除Oracle归档日志

如何正确删除Oracle归档日志

归档日志的存储空间在启动数据库后检查告警日志时提示该容量已使用81%,分析了一下,找到了原因,记录如下:

 

    在controlfile中记录着每个archivelog的相关信息,当我们在OS下把这些归档文件delete掉以后,这些信息并未从controlfile中清除,所以oracle并不知道这些文件已经不存在,所以相应的在容量上也并未调整,此时,需要我们做手工调整,使得controlfile中的记录与实际存在的归档日志文件保持一致。

 

可以尝试以下方法:

 

1. 进入rman 

 

2. connect target / 或者 connect target/@db_name

 

3. crosscheck archivelog all;

 

4. delete expired archivelog all;

 

以上语句的解释说明:

 

(1)crosscheck archivelog all:检查控制文件和实际物理文件的差别

 

(2)delete expired archivelog all:同步控制文件的信息和实际物理文件的信息

 

    如果单独执行 crosscheck 而不执行 delete 那么操作还是失败的,因为并未达到同步控制文件和实际物理文件的目的。

 

这时候我们再去OEM中看就一定看不到,如果你的从来没有做过这个动作的话,我们可以比较从这个动作前的controlfile后动作后的controlfile的大小!

 

 

 

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子项上做很多操作,实现更复杂的功能

 

 

 

简要介绍一下report obsolete命令

 

使用reportobsolete命令报告过期备份

 

RMAN> report obsolete;

 

RMAN retention policy will be applied tothe command

 

RMAN retention policy is set to redundancy1

 

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> deleteobsolete;

 

 

RMAN retentionpolicy will be applied to the command

 

RMAN retentionpolicy is set to redundancy 1

 

using channel ORA_DISK_1

 

Deleting the following obsolete backups andcopies:

 

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 aboveobjects (enter YES or NO)? yes

 

deleted backup piece

 

backup piecehandle=/data1/oracle/orabak/full_AVATAR2_20041206_173 recid=173 stamp=544156241

 

.....

 

deleted archivelog

 

archive logfilename=/opt/oracle/oradata/avatar2/archive/1_2715.dbf recid=2703stamp=545108268

 

deleted archivelog

 

archive log filename=/opt/oracle/oradata/avatar2/archive/1_2714.dbfrecid=2702 stamp=545107659

 

Deleted 286 objects

 

RMAN> crosscheck archivelog all;

 

released channel: ORA_DISK_1

 

allocated channel: ORA_DISK_1

 

channelORA_DISK_1: sid=19 devtype=DISK

 

specification does not match any archivelog in the recovery catalog

 

在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 对象

 

试着同步一下,看行不行,结果不行,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 对象

 

 

 

用list expired看看是否有失效的archive log,证明没有失效的archive log:

 

RMAN> list expired archivelog all;

 

 

说明与恢复目录中的任何存档日志均不匹配

 

 

 更改语言环境试试,结果再次crosscheck,2个archive log 都成功了:

 

RMAN> exit

 

恢复管理器完成。

 

C:>setnls_lang=american_america.zhs16gbk

 

C:>rmancatalogrman/rman@safetarget /

 

Recovery Manager: Release 9.2.0.1.0- Production

 

Copyright (c) 1995, 2002, OracleCorporation. 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 logfilename=D:ORACLEORADATATESTARCHIVE1_47.DBF recid=1 stamp=57286

 

6683

 

validation succeeded for archived log

 

archive logfilename=D:ORACLEORADATATESTARCHIVE11_48.DBF recid=2 stamp=5728

 

66931

 

Crosschecked 2 objects

 

 

补充:crosscheck backset 的使用

 

crosscheck backupset 是检查备份集和实际的文件

1 备份集有两种状态A(Available,RMAN认为该项存在于备份介质上)X(Expired,备份存在于控制文件或恢复目录中,但

是并没有物理存在于备份介质上)

2 crosscheck 的目的是检查RMAN 的目录以及物理文件,如果物理文件不存在于介质上,将标记为Expired。如果物理文件

存在,将维持Available。如果原先标记为Expired的备份集再次存在于备份介质上(如恢复了损坏的磁盘驱动器后),

crosscheck将把状态重新从Expired标记回Available。

3 crosscheck 输出分两部分。第一部分列出确定存在于备份介质上的所有备份集片,第二部分列出不存在于备份介质上的

备份集片,并将其标记为Expired。当设置备份保存策略后,一个备份过期,crosscheck之后标记为丢弃的备份状态依旧为

availabel,要删除丢弃备份delete obsolete

 

itpub一实例:

我的一个Unix下 oracle数据库在迁移当中一个归档文件丢失了,rman备份归档日志时提示 某个归档日志找不到,请问如何在不停止oracle数据库情况下 截断归档日志,重新开始新的归档!

 

crosscheck archivelog all

delete archivelog all;


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值