rman备份脚本shell版

简介:

1、数据库全备到硬盘

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[oracle@centos7 scripts]$  cat  rman_backup.sh  
source  /home/oracle/ .bash_profile  
rman target / log= /home/oracle/backup/backupall_rman .log<<EOF  
run  
{  
allocate channel ch1 device  type  disk;   #分配通道  
allocate channel ch2 device  type  disk;  
sql  'alter system archive log current' #归档当前日志  
backup database  format  '/home/oracle/backup/db_%d_%T_%U' ;     #备份数据文件
sql  'alter system archive log current' ;  
backup archivelog all  format  '/home/oracle/backup/arch_%t_%s'  delete all input;    #备份归档文件
backup  format  '/home/oracle/backup/con_%s_%p'  current controlfile;     #备份控制文件
crosscheck backup;  
crosscheck archivelog all;  
delete noprompt expired backup;  
delete noprompt obsolete;  
delete noprompt backup of database completed before  'sysdate -15' ;     #删除15天之前的数据库备份集
delete noprompt archivelog all;  
delete noprompt backup of archivelog all completed before  'sysdate -15' ;   #删除15天之前的归档备份集
release channel ch1;  
release channel ch2;  
}  
EOF

2、增量备份脚本

     0级增量


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[oracle@centos7 scripts]$  cat  rman_backup_level0.sh  
source  /home/oracle/ .bash_profile  
rman target / log= /home/oracle/backup/backupall_rman .log<<EOF  
run  
{  
allocate channel ch1 device  type  disk;   #分配通道  
allocate channel ch2 device  type  disk;  
sql  'alter system archive log current' #归档当前日志  
backup incremental level 0 database  format  '/home/oracle/backup/db_level0_%d_%T_%U' ;     #备份数据文件
sql  'alter system archive log current' ;  
backup archivelog all  format  '/home/oracle/backup/arch_level0_%t_%s'  delete all input;    #备份归档文件
backup  format  '/home/oracle/backup/con_level0_%s_%p'  current controlfile;     #备份控制文件
crosscheck backup;  
crosscheck archivelog all;  
delete noprompt expired backup;  
delete noprompt obsolete;  
delete noprompt backup of database completed before  'sysdate -15' ;     #删除15天之前的数据库备份集
delete noprompt archivelog all;  
delete noprompt backup of archivelog all completed before  'sysdate -15' ;   #删除15天之前的归档备份集
release channel ch1;  
release channel ch2;  
}  
EOF

     1级增量


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[oracle@centos7 scripts]$  cat  rman_backup_level1.sh  
source  /home/oracle/ .bash_profile  
rman target / log= /home/oracle/backup/backupall_rman .log<<EOF  
run  
{  
allocate channel ch1 device  type  disk;   #分配通道  
allocate channel ch2 device  type  disk;  
sql  'alter system archive log current' #归档当前日志  
backup incremental level 1 database  format  '/home/oracle/backup/db_level1_%d_%T_%U' ;     #备份数据文件
sql  'alter system archive log current' ;  
backup archivelog all  format  '/home/oracle/backup/arch_level1_%t_%s'  delete all input;    #备份归档文件
backup  format  '/home/oracle/backup/con_level1_%s_%p'  current controlfile;     #备份控制文件
crosscheck backup;  
crosscheck archivelog all;  
delete noprompt expired backup;  
delete noprompt obsolete;  
delete noprompt backup of database completed before  'sysdate -15' ;     #删除15天之前的数据库备份集
delete noprompt archivelog all;  
delete noprompt backup of archivelog all completed before  'sysdate -15' ;   #删除15天之前的归档备份集
release channel ch1;  
release channel ch2;  
}  
EOF

注意:1级备份需要在0级备份的基础上执行。


3、支持全备和增量备份

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
[oracle@centos7 scripts]$  cat  db_back_rman.sh  
##===========================================================  
##   db_bak_rman.sh                
##   created by Robinson           
##   2017/12/15    
##   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




















本文转自lq201151CTO博客,原文链接:http://blog.51cto.com/liuqun/2051173 ,如需转载请自行联系原作者









相关文章
|
2月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
389 9
|
2月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
255 2
|
5月前
|
Shell
Shell脚本循环控制:shift、continue、break、exit指令
使用这些命令可以让你的Shell脚本像有生命一样动起来。正确使用它们,你的脚本就能像一场精心编排的舞蹈剧目,既有旋律的起伏,也有节奏的跳跃,最终以一场惊艳的表演结束。每一个动作、每一个转折点,都准确、优雅地完成所需要表达的逻辑。如此,你的脚本不只是冰冷的代码,它透过终端的界面,跳着有节奏的舞蹈,走进观众——使用者的心中。
240 60
|
2月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。
|
8月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
4月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
466 1
|
6月前
|
存储 Unix Shell
确定Shell脚本在操作系统中的具体位置方法。
这对于掌握Linux的文件系统组织结构和路径方面的理解很有帮助,是我们日常工作和学习中都可能使用到的知识。以上讲解详细清晰,应用简便,是每一个想要精通操作系统的计算机爱好者必备的实用技能。
158 17
|
6月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
179 4
|
6月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
362 3
|
7月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
590 25