日期:2014-05-16 浏览次数:20389 次
如果我们打开oracle的归档模式,那么在数据文件吞噬着硬盘空间的同时,归档文件也在无声无息中占用着我们的硬盘空间 一般生产系统都会有良好的备份机制,所以归档日志是可以删除的,下面就是通过脚本的方式将它们安全删除掉的方法: vi delet_archive.sh . /home/oracle/.bash_profile LOGFILE=/data/rman/rman_delete.log RMAN=$ORACLE_HOME/bin/rman WEEK=$((`date +%w`)) date=`date +%Y-%m-%d` echo "----------------------------begin backup ----------------------------------" >> $LOGFILE date >>$LOGFILE sh /data/rman/script/archive_delete.rman $RMAN $LOGFILE date >>$LOGFILE echo "---------------------------end backup ---------" >> $LOGFILE vi archivelog_delete.sh $ORACLE_HOME/bin/rman <<EOF connect target sys/password@mydb crosscheck 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删除就可以了。?