通过Rman定期删除归档脚本
如果我们打开oracle的归档模式,那么在数据文件吞噬着硬盘空间的同时,归档文件也在无声无息中占用着我们的硬盘空间一般生产系统都会有良好的备份机制,所以归档日志是可以删除的,下面就是通过脚本的方式将它们安全删除掉的方法:vi delet_archive.sh. /home/oracle/.bash_profileLOGFILE=/data/rman/rman_delete.logRMAN=$ORACLE_HOME/bin/rmanWEEK=$((`date +%w`))date=`date +%Y-%m-%d`echo "----------------------------begin backup ----------------------------------" >> $LOGFILEdate >>$LOGFILEsh /data/rman/script/archive_delete.rman $RMAN $LOGFILEdate >>$LOGFILEecho "---------------------------end backup ---------" >> $LOGFILEvi archivelog_delete.sh$ORACLE_HOME/bin/rman <<EOFconnect target sys/password@mydbcrosscheck archivelog all;delete noprompt expired archivelog all;delete noprompt archivelog until time 'sysdate-7';exit;EOF脚本编写好后,在 oracle 用户下使用 crontab -e 进行编辑 设定定时执行的时间:30 0 * * * sh /data/rman/script/rman_delete.sh最后转贴一点别人的成果:删除acrhivelog,最好用rman delete, 实际上在写脚本的时候,用OS的rm删除archivelog路径下的物理文件也可以,然后执行 crosscheck 和 delete expired ,但是这种方法在遇到ASM存储的时候实现起来会比较麻烦,所以建议用rman delete的方法。另外,用 rman delete的时候可能会报:RMAN-08137: WARNING: archived log not deleted, needed for standby or upstream capture process尝试删除归档日志,oracle提示这些归档日志还要用到standby数据库上面,不让删除,这个特点不错,可以避免由于没有同步standby而误删除archivelog的情况。要删除,需要加上FORCE删除就可以了。?