oracle的oem管理器中有可视化的日志展现出,当我们手工清除archive目录下的文件后,这些记录并没有被我们从controlfile中清除掉,
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数据备份工具
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 commandrman retention policy is set to redundancy 1report of obsolete backups and copiestype key completion time filename/handle-------------------- ------ ------------------ --------------------backup set 125 01-nov-04backup piece 125 01-nov-04 /data1/oracle/orabak/full_1_541045804backup set 131 04-nov-04backup piece 131 04-nov-04 /data1/oracle/orabak/full_avatar2_20041104_131....backup set 173 06-dec-04backup piece 173 06-dec-04 /data1/oracle/orabak/full_avatar2_20041206_173backup set 179 11-dec-04backup piece 179 11-dec-04 /data1/oracle/orabak/arch544588206.arc.....backup piece 189 17-dec-04 /data1/oracle/orabak/arch545106606.arcbackup set 190 17-dec-04backup piece 190 17-dec-04 /data1/oracle/orabak/arch545106665.arcbackup set 191 20-dec-04backup piece 191 20-dec-04 /data1/oracle/orabak/arch_avatar2_20041220_194archive log 2973 20-dec-04 /opt/oracle/oradata/avatar2/archive/1_2985.dbfarchive 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.dbfarchive log 2704 17-dec-04 /opt/oracle/oradata/avatar2/archive/1_2716.dbfarchive log 2703 17-dec-04 /opt/oracle/oradata/avatar2/archive/1_2715.dbfarchive 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 commandrman retention policy is set to redundancy 1using channel ora_disk_1deleting the following obsolete backups and copies:type key completion time filename/handle-------------------- ------ ------------------ --------------------backup set 125 01-nov-04backup piece 125 01-nov-04 /data1/oracle/orabak/full_1_541045804....archive log 2704 17-dec-04 /opt/oracle/oradata/avatar2/archive/1_2716.dbfarchive log 2703 17-dec-04 /opt/oracle/oradata/avatar2/archive/1_2715.dbfarchive log 2702 17-dec-04 /opt/oracle/oradata/avatar2/archive/1_2714.dbfdo you really want to delete the above objects (enter yes or no)? yesdeleted backup piecebackup piece handle=/data1/oracle/orabak/full_avatar2_20041206_173 recid=173 stamp=544156241.....deleted archive logarchive log filename=/opt/oracle/oradata/avatar2/archive/1_2715.dbf recid=2703 stamp=545108268deleted archive logarchive log filename=/opt/oracle/oradata/avatar2/archive/1_2714.dbf recid=2702 stamp=545107659deleted 286 objectsrman> crosscheck archivelog all;released channel: ora_disk_1allocated channel: ora_disk_1channel ora_disk_1: sid=19 devtype=diskspecification 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