您的位置:首页 > 其它

计划任务执行rman备份

2013-02-03 15:17 239 查看
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备份的计划任务完成!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: