您好,欢迎访问一九零五行业门户网

Oracle归档日志的清楚

我们都都知道在controlfile中记录着每一个archivelog的相关信息,当然们在os下把这些物理文件delete掉后,在我们的controlfile中
我们都都知道在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
其它类似信息

推荐信息