咱们都知道在controlfile中记录着每个archivelog文件的相关信息,固然们在OS下把这些物理文件delete掉后,在咱们的controlfile中仍然记录着这些archivelog文件的相关信息,在oracle的OEM管理器中有可视化的日志展示出,当咱们手工清除 archive目录下的文件后,这些记录并无被咱们从controlfile中清除掉,也就是oracle并不知道这些文件已经不存在了,这时候咱们要作手工的清除的话,下面我通过实验,能够尝试这种方法:数据库
1. 进入rman 服务器
[oracle@dthxdb2 ~]$ /u01/app/oracle/product/10.2.0/db/bin/rman (或 rman)
网络
2. connect target / 注:(若是磁盘空间满了的话是链接不上的,须要提早清理一些空间才能进行链接)oracle
RMAN> connect target /
app
3. crosscheck archivelog all;
crosscheck archivelog all:验证的是DB的归档日志即log_archive_dest参数指定位置的文件,当手工删除了归档日志之后,Rman备份会检测到日志缺失,从而没法进一步继续执行Rman备份,因此此时须要手工执行crosscheck过程,查看全部的归档日志文件是否都是正常的而后再来执行Rman备份。
工具
4. delete expired archivelog all;
这时候咱们再去OEM中就看不到这些日志文件了,若是你的历来没有作过这个动做的话,咱们能够比较这个动做前的controlfile和动做后的controlfile的文件大小spa
ORACLE正确删除归档并回收空间的方法:
一个ORACLE归档日志常常满,表现为/archivelog这个文件空间占用100%你们老是抱怨ORACLE为什么没有归档维护工具,不少人直接删除了事,错了,ORACLE有,并且很智能,能够正确的删除归档和 FLASHBACK,不过切记,ORACLE归档日志对于ORACLE的数据恢复和备份很是重要,不到万不得已不要删除归档日志。
操作系统
删除归档日志的过程:
以ORACLE用户身份登陆到数据库服务器主机或经过网络链接.net
进入ORACLE数据备份工具:
/u01/app/oracle/product/10.2.0/db/bin/rman target/
或/u01/app/oracle/product/10.2.0/db/bin/rman target/@DTHXRAC1
日志
在命令窗口里面执行:
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 /archivelog -xdev -mtime +7 -name "*.dbf" -exec rm -f {} \; (这种方式我的理解是:删除数据文件中7天前的数据、可是不删除该数据文件)有待验证
这样作仍然会在RMAN里留下未管理的归档文件,它的做用仍是至关于直接用操做系统命令将归档日志文件直接删除,而ORACLE控制文件并不知道,所以仍须要在RMAN里执行下面2条命令:
crosscheck archivelog all;
delete expired archivelog all; (我的理解是删除contorl 文件中的标记 使得能够进行作rman 全备份)
因此还不如上面的方法好用,不过用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
转自于:https://blog.csdn.net/dbdeep/article/details/78510687 博文
因为时间的缘由、没有完整的总结本身实际中遇到过的一些场景 ^_^ 关于以上部分标记的我的理解、若是有不正确的地方还请大神指教!