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/2051172 ,如需转载请自行联系原作者


相关文章
|
2月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
107 1
|
1月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
59 2
6种方法打造出色的Shell脚本
|
28天前
|
缓存 监控 Shell
如何使用 HBase Shell 进行数据的实时监控和备份?
如何使用 HBase Shell 进行数据的实时监控和备份?
|
25天前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
53 1
|
1月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
45 2
|
2月前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
51 6
|
1月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
79 12
|
2月前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
69 2
|
2月前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
34 0