计划任务执行rman备份

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 script
DATE=`/bin/date +%Y%m%d`
cd ~/shell
echo "$DATE ---- backup is begin..." >> /home/oracle/shell/backup_info.log
export ORACLE_SID=test
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export PATH=$ORACLE_HOME/bin:$PATH
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
必须加上oracle用户的环境变量,下面的rman命令才能执行
rman target / @t.rman  >> /home/oracle/shell/backup_info.log
echo "$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备份的计划任务完成!!


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章