linux 下RMAN备份shell脚本
RMAN备份对于Oracle数据库的备份与恢复简单易用,成本低廉。对于使用非catalog方式而言,将RMAN脚本嵌入到shell脚本,然后再通过crontab来实现中小型数据库数据库备份无疑是首选。本文提供了一个简单易用的基于linux shell下的RMAN备份脚本供参考。大家可根据自己的需要进行适当调整。
RMAN备份相关方面的知识较多,可以参考:
RMAN 概述及其体系结构 RMAN 配置、监控与管理 RMAN 备份详解 RMAN 还原与恢复 RMAN catalog 的创建和使用 基于catalog 创建RMAN存储脚本 基于catalog 的RMAN 备份与恢复 RMAN 备份路径困惑
其次是对于shell脚本中调用sql,rman语句可以参考
Linux/Unix shell 脚本中调用SQL,RMAN脚本
Linux/Unix shell sql 之间传递变量
下面是脚本的具体内容
- ##===========================================================
- ## db_bak_rman.sh
- ## created by Robinson
- ## 2011/11/07
- ## usage: db_bak_rman.sh <$ORACLE_SID> <$BACKUP_LEVEL>
- ## BACKUP_LEVEL:
- ## F: full backup
- ## 0: level 0
- ## 1: level 1
- ##============================================================
- #!/bin/bash
- # User specific environment and startup programs
- if [ -f ~/.bash_profile ];
- then
- . ~/.bash_profile
- fi
- ORACLE_SID=${1}; export ORACLE_SID
- RMAN_LEVEL=${2}; export RMAN_LEVEL
- TIMESTAMP=`date +%Y%m%d%H%M`; export TIMESTAMP
- DATE=`date +%Y%m%d`; export DATE
- RMAN_DIR=/u02/database/${ORACLE_SID}/backup/rman; export RMAN_DIR
- RMAN_DATA=${RMAN_DIR}/${DATE}; export RMAN_DATA
- #RMAN_LOG=$RMAN_DATA/log; export RMAN_LOG
- RMAN_LOG=/u02/database/${ORACLE_SID}/backup/rman/log export RMAN_LOG
- # Check rman level
- #======================================================================
- if [ "$RMAN_LEVEL" == "F" ];
- then unset INCR_LVL
- BACKUP_TYPE=full
- else
- INCR_LVL="INCREMENTAL LEVEL ${RMAN_LEVEL}"
- BACKUP_TYPE=lev${RMAN_LEVEL}
- fi
- RMAN_FILE=${RMAN_DATA}/${ORACLE_SID}_${BACKUP_TYPE}_${TIMESTAMP}; export RMAN_FILE
- SSH_LOG=${RMAN_LOG}/${ORACLE_SID}_${BACKUP_TYPE}_${TIMESTAMP}.log; export SSH_LOG
- MAXPIECESIZE=4G; export MAXPIECESIZE
- #Check RMAN Backup Path
- #=========================================================================
- if ! test -d ${RMAN_DATA}
- then
- mkdir -p ${RMAN_DATA}
- fi
- echo "---------------------------------" >>${SSH_LOG}
- echo " " >>${SSH_LOG}
- echo "Rman Begin to Working ........." >>${SSH_LOG}
- echo "Begin time at:" `date` --`date +%Y%m%d%H%M` >>${SSH_LOG}
- #Startup rman to backup
- #=============================================================================
- $ORACLE_HOME/bin/rman log=${RMAN_FILE}.log <<EOF
- connect target /
- run {
- CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 3 DAYS;
- CONFIGURE BACKUP OPTIMIZATION ON;
- CONFIGURE CONTROLFILE AUTOBACKUP ON;
- CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '${RMAN_FILE}_%F';
- ALLOCATE CHANNEL 'ch1' TYPE DISK maxpiecesize=${MAXPIECESIZE};
- ALLOCATE CHANNEL 'ch2' TYPE DISK maxpiecesize=${MAXPIECESIZE};
- set limit channel ch1 readrate=10240;
- set limit channel ch1 kbytes=4096000;
- set limit channel ch2 readrate=10240;
- set limit channel ch2 kbytes=4096000;
- CROSSCHECK ARCHIVELOG ALL;
- DELETE NOPROMPT EXPIRED ARCHIVELOG ALL;
- BACKUP
- #AS COMPRESSED BACKUPSET
- ${INCR_LVL}
- DATABASE FORMAT '${RMAN_FILE}_%U' TAG '${ORACLE_SID}_${BACKUP_TYPE}_${TIMESTAMP}';
- SQL 'ALTER SYSTEM ARCHIVE LOG CURRENT';
- BACKUP ARCHIVELOG ALL FORMAT '${RMAN_FILE}_arc_%U' TAG '${ORACLE_SID}_arc_${TIMESTAMP}'
- DELETE INPUT;
- DELETE NOPROMPT OBSOLETE;
- RELEASE CHANNEL ch1;
- RELEASE CHANNEL ch2;
- }
- sql "alter database backup controlfile to ''${RMAN_DATA}/cntl_${BACKUP_TYPE}.bak''";
- exit;
- EOF
- RC=$?
- cat ${RMAN_FILE}.log >>${SSH_LOG}
- echo "Rman Stop working @ time:"`date` `date +%Y%m%d%H%M` >>${SSH_LOG}
- echo >>${SSH_LOG}
- echo "------------------------" >>${SSH_LOG}
- echo "------ Disk Space ------" >>${SSH_LOG}
- df -h >>${SSH_LOG}
- echo >>${SSH_LOG}
- if [ $RC -ne "0" ]; then
- echo "------ error ------" >>${SSH_LOG}
- else
- echo "------ no error found during RMAN backup peroid------" >>${SSH_LOG}
- rm -rf ${RMAN_FILE}.log
- fi
- #Remove old backup than 3 days
- #============================================================================
- RMDIR=${RMAN_DIR}/`/bin/date +%Y%m%d -d "3 days ago"`; export RMDIR
- echo >>${SSH_LOG}
- echo -e "------Remove old backup than 3 days ------\n" >>${SSH_LOG}
- if test -d ${RMDIR}
- then
- rm -rf ${RMDIR}
- RC=$?
- fi
- echo >>${SSH_LOG}
- if [ $RC -ne "0" ]; then
- echo -e "------ Remove old backup exception------ \n" >>${SSH_LOG}
- else
- echo -e "------ no error found during remove old backup set peroid------ \n" >>${SSH_LOG}
- fi
- exit
- oracle@SZDB:~/robinson/scripts/dba_scripts/custom/sql> ./db_bak_rman.sh GOBO1 0
- RMAN> RMAN> 2> 3> 4> 5> 6> 7> 8> 9> 10> 11> 12> 13> 14> 15>
- 16> 17> 18> 19> 20> 21> 22> 23> 24> RMAN> RMAN>
- oracle@SZDB:~/robinson/scripts/dba_scripts/custom/sql>
- oracle@SZDB:/u02/database/GOBO1/backup/rman> ls
- 20120928 log
- oracle@SZDB:/u02/database/GOBO1/backup/rman/20120928> ls
- cntl_lev0.bak GOBO1_lev0_201209281421_arc_4onmb9ro_1_1
- GOBO1_lev0_201209281421_4knmb9jn_1_1 GOBO1_lev0_201209281421_c-733951103-20120928-00
- GOBO1_lev0_201209281421_4lnmb9jn_1_1 GOBO1_lev0_201209281421_c-733951103-20120928-01
- GOBO1_lev0_201209281421_arc_4nnmb9rn_1_1
- 转:http://blog.csdn.net/leshami/article/details/8029245
linux 下RMAN备份shell脚本的更多相关文章
- 在Linux下如何用Shell脚本读写XML?现有一个config.xml(转)
在Linux下如何用Shell脚本读写XML?现有一个config.xml <?xml version="1.0" encoding="UTF-8"?&g ...
- Linux下如何执行Shell脚本
Linux下你可以有两种方式执行Shell脚本: 1.用shell程序执行脚本:根据你的shell脚本的类型,选择shell程序,常用的有sh,bash,tcsh等(一般来说第一行#!/bin/bas ...
- linux下如何编写shell脚本
我对shell脚本的认识,除了执行过同事写的shell 脚本外,其他一无所知,为了让自己强大,我决定自己研究shell脚本,也许在你看来很简答,没必要说这么多废话,但是我希望在我的技术log里记录下来 ...
- linux下后台执行shell脚本nohup
(一)使用nohup后台执行脚本 脚本执行结果记录到nohup.out文件中 (二)使用&后台执行脚本 使用&符号在后台执行命令或脚本后,如果你退出登录,这个命令就会被自动终止掉
- Linux下定时备份MySQL数据库的Shell脚本
Linux下定时备份MySQL数据库的Shell脚本 对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间 ...
- Linux 平台下 RMAN 全备 和 增量备份 shell 脚本
转:http://blog.csdn.net/tianlesoftware/article/details/5740630 全备脚本 以 nocatalog 模式为例: Shell 脚本: ##### ...
- Debian下自动备份文件并上传到远程FTP服务器且删除指定日期前的备份Shell脚本
说明: 1.备份目录/home/osyunwei下面所有的文件到/home/osyunweibak里面,并且保存为osyunwei20120701.tar.gz的压缩文件格式(2012_07_01是 ...
- Linux下自动备份MySQL数据库并上传到远程FTP服务器
Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...
- Linux下远程备份、上传工程,重启服务器
Linux下远程备份.上传工程,重启服务器 Linux服务器实现远程,原项目的备份.删除,新项目上传,以及远程重启服务器!分成一个主shell调用三个shell文件步骤完成.mainsh.sh一次按顺 ...
随机推荐
- jmeter中线程之间传递参数
JMeter 变量作用域局限于所属线程.这样设计是经过深思熟虑的,目的是让测试线程能够独立运转.有时候用户可能需要在不同线程间(可能属于同一个线程组,也可能不属于同一个线程组)传递变量. 其中一种方法 ...
- 【PSR规范专题(5)】PSR-4 改进后的自动加载规范
本文转自: https://github.com/PizzaLiu/PHP-FIG/blob/master/PSR-4-autoloader-cn.md 关键词 "必须"(&quo ...
- iOS 开发--多线程
前面在<Bison眼中的iOS开发多线程是这样的(二)>一文中讲完了多线程的NSThread,不难发现这种方式的多线程实现起来非常的复杂,为了简化多线程的开发,iOS提供了GCD来实现多线 ...
- Java-数据结构与算法-二分查找法
1.二分查找法思路:不断缩小范围,直到low <= high 2.代码: package Test; import java.util.Arrays; public class BinarySe ...
- 在编辑框(CEdit)控件上追加内容
版权声明:本文为博主原创文章,未经博主允许不得转载. // MFC 版本 CEdit* pEdit = GetDlgItem(IDC_EDIT1); ASSERT(pEdit && p ...
- WordPress主题制作教程2:导航菜单制作
实现自定义菜单,需要用到的函数是wp_nav_menu(); 在主题目录下的functions.php的 <?php ….. ?> 之间,添加以下菜单注册代码,这样你就可以在主题文件中使用 ...
- http://blog.csdn.net/lvyuanj/article/details/51235135
http://blog.csdn.net/lvyuanj/article/details/51235135
- sql查询字段值的换行及回车符
SQL的换行.回车符,在MySQL.SQL Server和Oracle中均有不同,下面以列表显示. MySQL SQL Server Oracle 换行符 \n或\r\n或CHAR(10) CHA ...
- ubuntu下安装与测试mysql
1.在决定安装mysql之前,要先确定系统是否已经安装mysql. 输入: 1 mysql 结果:说明尚未安装mysql The program 'mysql' is currently notins ...
- 蒙特罗卡π算法(C++语言描述)
圆的面积计算公式为:S=π*r*r 将圆放到一个直角坐标系中,如图黄色部分的面积是S/4=(π*r*r)/4;如果我们将取一个单位圆,则S/4=π/4. 因为是单位圆,半径为1,所以图中红色正方形的面 ...