您的位置:首页 > 运维架构 > Linux

每天定时任务自动清理旧的归档文件 【Linux服务器】

2016-08-06 22:33 239 查看
将 clear_oracle_archivelog 文件放到 /etc/init.d 目录下,

clear_flash_recovery_area_commend.txt 文件存放到/oracle目录下,该路径可以通过 clear_oracle_archivelog 文件的 RMAN_CMDFILE 变量指定修改。

说明:clear_oracle_archivelog 是清理归档日志的服务,改服务依赖clear_flash_recovery_area_commend.txt 文件

clear_flash_recovery_area_commend.txt

DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-2';


clear_oracle_archivelog

#!/bin/sh
# chkconfig: 35 81 10
# description: 清理两天前的归档日志
ORA_HOME=/oracle/product/database
ORA_OWNER=yh.zeng
RMAN_TARGET=sys/Sa12345678@rac
RMAN_CMDFILE=/oracle/clear_flash_recovery_area_commend.txt
LOGFILE=/var/log/clear_oracle_archivelog
RETVAL=0
case "$1" in
'start')
date +" %T %a %D : 清理两天前的归档日志 ..." >> $LOGFILE
echo "清理两天前的归档日志 ... "
su - $ORA_OWNER -c "$ORA_HOME/bin/rman target '$RMAN_TARGET' cmdfile '$RMAN_CMDFILE'" >> $LOGFILE 2>&1
echo "完成" >> $LOGFILE
;;
*)
echo $"Usage: $0 {start}"
RETVAL=1
;;
esac
exit $RETVAL


修改 clear_flash_recovery_area里面的变量, 要做的修改如下:

1)ORA_HOME, 该变量值为 oracle数据库安装根目录

2)ORA_OWNER,该变量值为 数据库管理员身份的系统用户

3)RMAN_TARGET, 该变量值为 用户名/密码@数据库服务名

4)RMAN_CMDFILE,该变量值为 实际要执行的指令文件地址,包含文件名

5)LOGFILE, 该变量值为 该服务的日志输出文件

修改 clear_flash_recovery_area_commend.txt里面的指令,修改BEFORE参数,该参数值是指定哪个时间点之前的归档文件要删除掉

修改/etc/crontab文件,让系统每天晚上10点钟启动clear_oracle_archivelog服务,添加的内容如下

0 22 * * * root /etc/init.d/clear_oracle_archivelog start


开机启动clear_oracle_archivelog服务,执行如下命令

#chkconfig  --add  clear_oracle_archivelog
#chkconfig  --level  345  clear_oracle_archivelog  on
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐