计划任务执行rman备份

来源:互联网 发布:pdf听书软件 编辑:程序博客网 时间:2024/05/20 01:47

oracle备份目标:

1:每天晚上2点执行数据库全备

2:备份集保留2份

server环境:

oracle: 11g2  64bit

centos: 5.8     64bit

以下为脚本代码:

rman脚本:

run{ set backup copies 2;   指定备份集 为2份 。要修改 备份策略 中冗余份为2份  backup device type disk format '/u01/t/1/1_%U.bak','/u01/t/2/2_%U.bak' database plus archivelog filesperset 20 delete all input; 指定数据库全备(包括归档日志,filesperset 20 表示归档日志备份集中最多只能包含20个归档日志文件) 并指定其路径,备份完成后删除已经备份的归档日志文件 }allocate channel for maintenance device type disk;为crosscheck,delete操作指定专用通道crosscheck backupset;delete noprompt obsolete;直接删除过期备份,不用交互提醒


将该脚本保存为:t.rman

编写shell脚本:

#!/bin/sh#this is backup database scriptDATE=`/bin/date +%Y%m%d`cd ~/shellecho "$DATE ---- backup is begin..." >> /home/oracle/shell/backup_info.logexport ORACLE_SID=testexport ORACLE_BASE=/u01/app/oracleexport ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1export PATH=$ORACLE_HOME/bin:$PATHexport NLS_LANG=AMERICAN_AMERICA.ZHS16GBK必须加上oracle用户的环境变量,下面的rman命令才能执行rman target / @t.rman  >> /home/oracle/shell/backup_info.logecho "$DATE ---- backup is over!!" >> /home/oracle/shell/backup_info.log


保存脚本为 t.sh。

注意:

rman脚本和shell脚本需放在同一个目录下

在oracle用户下创建计划任务:

crontab -e
0 2 *** /bin/sh/home/oracle/shell/t.sh

此时 rman备份的计划任务完成!!