1、如何正确删除 Oracle 归档日志归档日志的存储空间在启动数据库后检查告警日志时提示该容量已使用 81%,分析了一下,找到了原因,记录如下:在 controlfile 中记录着每个 archivelog 的相关信息, 当我们在 OS 下把这些归档文件delete 掉以后,这些信息并未从 controlfile 中清除,所以 oracle 并不知道这些文件已经不存在,所以相应的在容量上也并未调整,此时,需要我们做手工调整,使得 controlfile 中的记录与实际存在的归档日志文件保持一致。可以尝试以下方法:1. 进入 rman 2. connect target / 或者 connect
2、target/db_name(连接远程数据库如果要连接的目标数据库是一个远程数据库,那么必须在建立连接时指定一个有效的网络服务名,同时你本地的 tnsname.ora 文件中也必须已经建立了该网络服务名的正确配置。示例如下:C:Documents and SettingsAdministratorrman target sys/change_on_installtestdb)3. crosscheck archivelog all;4. delete expired archivelog all;以上语句的解释说明:(1)crosscheck archivelog all:检查控制文件和实际物
3、理文件的差别(2)delete expired archivelog all:同步控制文件的信息和实际物理文件的信息如果单独执行 crosscheck 而不执行 delete 那么操作还是失败的,因为并未达到同步控制文件和实际物理文件的目的。这时候我们再去 OEM 中看就一定看不到,如果你的从来没有做过这个动作的话,我们可以比较从这个动作前的 controlfile 后动作后的 controlfile 的大小!ORACLE 正确删除归档并回收空间的方法一个 ORACLE 归档日志经常满,表现为/oraarchive 这个文件空间占用 100大家一定抱怨 ORACLE 为何没有归档维护工具,很多
4、人直接删除了事,错了,ORACLE 有,而且很智能,可以正确的删除归档和 FLASHBACK,不过切记,ORACLE 归档日志对于ORACLE 的数据恢复和备份非常重要,不到万不得已不要删除归档日志。删除归档日志的过程:以 ORACLE 用户身份登录到数据库服务器主机或通过网络连接进入 ORACLE 数据备份工具rman target/或 rman target/orcl在命令窗口里面执行DELETE ARCHIVELOG ALL COMPLETED BEFORE SYSDATE-7;说明:SYSDATA-7,表明当前的系统时间 7 天前,before 关键字表示在 7 天前的归档日志,如果使
5、用了闪回功能,也会删除闪回的数据。同样道理,也可以删除从 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 ex
6、pired archivelog all;所以还不如上面的方法好用,不过用 FIND 的好处就是,可以在条件上,和 EXEC 子项上做很多操作,实现更复杂的功能简要介绍一下 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 Compl
7、etion 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_131Backup Set 173 06-DEC-04Backup Piece 173 06-DEC-04 /data1/oracle/orabak/full_AVATA
8、R2_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
9、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-
10、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使用 delete obsolete 命令删除过期备份 :RMAN delete obsolete;RMAN retention policy will be applied to the commandRMA
11、N 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_541045804Archive Log 2704 17-DEC-04 /opt/oracle/oradata/av
12、atar2/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/
13、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 objectsRMA
14、N 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在 rman 中用 crosscheck 检查归档日志,2 个归档日志都是失败的:RMAN crosscheck archivelog all;释放的通道: ORA_DISK_1分配的通道: ORA_DISK_1通道
15、 ORA_DISK_1: sid=14 devtype=DISK对归档日志的验证失败存档日志文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 记录 ID=1 时间戳 =572866683对归档日志的验证失败存档日志文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 记录 ID=2 时间戳 =572866931已交叉检验的 2 对象试着同步一下,看行不行,结果不行,crosscheck 还是失败:RMAN resync catalog;正在启动全部恢复目录的 resync完成全部 resyncRMAN crosscheck archiv
16、elog all;释放的通道: ORA_DISK_1分配的通道: ORA_DISK_1通道 ORA_DISK_1: sid=14 devtype=DISK对归档日志的验证失败存档日志文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 记录 ID=1 时间戳 =572866683对归档日志的验证失败存档日志文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 记录 ID=2 时间戳 =572866931已交叉检验的 2 对象用 list expired 看看是否有失效的 archive log,证明没有失效的 archive log:RMA
17、N list expired archivelog all;说明与恢复目录中的任何存档日志均不匹配更改语言环境试试,结果再次 crosscheck,2 个 archive log 都成功了:RMAN exit恢复管理器完成。C:set nls_lang=american_america.zhs16gbkC:rman catalogrman/rmansafetarget /Recovery Manager: Release 9.2.0.1.0 - ProductionCopyright (c) 1995, 2002, Oracle Corporation. All rights reserved
18、.connected to target database: TEST (DBID=1870953724)connected to recovery catalog databaseRMAN crosscheck archivelog all;allocated channel: ORA_DISK_1channel ORA_DISK_1: sid=9 devtype=DISKvalidation succeeded for archived logarchive log filename=D:ORACLEORADATATESTARCHIVE1_47.DBF recid=1 stamp=5728
19、66683validation succeeded for archived logarchive log filename=D:ORACLEORADATATESTARCHIVE11_48.DBF recid=2 stamp=572866931Crosschecked 2 objects补充:crosscheck backset 的使用crosscheck backupset 是检查备份集和实际的文件1 备份集有两种状态 A(Available,RMAN 认为该项存在于备份介质上)X(Expired,备份存在于控制文件或恢复目录中,但是并没有物理存在于备份介质上)2 crosscheck 的目
20、的是检查 RMAN 的目录以及物理文件,如果物理文件不存在于介质上,将标记为 Expired。如果物理文件存在,将维持 Available。如果原先标记为 Expired 的备份集再次存在于备份介质上(如恢复了损坏的磁盘驱动器后) ,crosscheck 将把状态重新从 Expired 标记回 Available。3 crosscheck 输出分两部分。第一部分列出确定存在于备份介质上的所有备份集片,第二部分列出不存在于备份介质上的备份集片,并将其标记为 Expired。当设置备份保存策略后,一个备份过期,crosscheck 之后标记为丢弃的备份状态依旧为availabel,要删除丢弃备份 delete obsoleteitpub 一实例:我的一个 Unix 下 oracle 数据库在迁移当中一个归档文件丢失了,rman 备份归档日志时提示 某个归档日志找不到,请问如何在不停止 oracle 数据库情况下 截断归档日志,重新开始新的归档!crosscheck archivelog alldelete archivelog all;