Oracle RMAN 无敌备份脚本

1 说明

上一篇文章:Oracle逻辑备份脚本,介绍了如何部署Oracle数据库的逻辑备份脚本,在数据迁移场景下十分好用,但是作为备份来说有点牵强。仅仅有逻辑备份时,当故障发生后,逻辑备份恢复只能恢复到某一时刻,无法做到完全恢复,会发生数据丢失。

RMAN是Oracle数据库软件自带的备份/恢复工具,它能够备份整个数据库或数据库部件,如表空间、数据文件、控制文件、归档文件以及Spfile参数文件。通过RMAN的方式无论是要备份还是要恢复,都必须先启动实例并加载数据库。

本篇文章主要介绍如何去部署一份RMAN热备脚本,采用全备+归档备份的方式:

  • 全备:每周一次;
  • 归档备份:每天一次。

为什么不采用全备+增倍?主要是由于归档备份恢复起来比较灵活,可以恢复到任意时间点。并且归档日志备份不依赖于前置的备份,这样备份链的某一部分损坏不会影响到其他备份的有效性。

2 准备工作

准备工作主要包括脚本路径创建和RMAN配置。

2.1 脚本路径创建

脚本部署在ORCLE_BASE下,使用oracle用户,创建脚本目录:

$ cd /u01/app/oracle/
$ mkdir -p rman/src
$ mkdir -p rman/log
$ mkdir -p rman/ctl$ tree rman/
rman/
|-- ctl
|-- log
`-- src
3 directories, 0 files

src目录用于存放脚本,log目录用于存放备份日志,ctl目录用于存放自动备份的控制文件。

2.2 RMAN配置保留策略

保留策略有两种类型:recovery window(恢复窗口)和redundancy(冗余)。

通常使用冗余保留策略,保留2份备份。

RMAN> CONFIGURE RETENTION POLICY TO REDUNDANCY 2;new RMAN configuration parameters:
CONFIGURE RETENTION POLICY TO REDUNDANCY 2;
new RMAN configuration parameters are successfully storedRMAN> show RETENTION POLICY;RMAN configuration parameters for database with db_unique_name ORCL are:
CONFIGURE RETENTION POLICY TO REDUNDANCY 2;

3 全备脚本部署

3.1 脚本说明

3.2 编辑脚本

oracle用户进入脚本目录,创建并编辑脚本:

$ cd /u01/app/oracle/rman/src
$ vi rman_orcl_full_weekly.sh

脚本内容如下:

#!/bin/bashif [ -f $HOME/.bash_profile ];
thenexport ORAENV_ASK=NO. $HOME/.bash_profile
fi# ---------------------------------------------------------------
# environment variables
# ---------------------------------------------------------------
export ORACLE_HOME=/u01/app/oracle/product/11.2/db_1
export ORACLE_SID=orcl
DATE=`date +'%Y%m%d%H'`RMANBASE=/u01/app/oracle/rman
SCRIPTDIR=${RMANBASE}/src
LOGDIR=${RMANBASE}/log
CTLDIR=${RMANBASE}/ctlRMAN_LOG_FILE=${LOGDIR}/${DATE}_${ORACLE_SID}_RMAN_FULL.log# ---------------------------------------------------------------
# begin
# ---------------------------------------------------------------echo 'Run Script' $0 >> ${RMAN_LOG_FILE}
echo -e "\n****** Rman Full Backup started on `date +'%F %T'` ******\n" >> ${RMAN_LOG_FILE}# ---------------------------------------------------------------
# rman full backup
# ---------------------------------------------------------------rman target / msglog ${RMAN_LOG_FILE} append << EOF
run {
allocate channel ch00 type disk;
allocate channel ch01 type disk;
allocate channel ch02 type disk;
allocate channel ch03 type disk;sql 'alter system archive log current';backup databasefilesperset 1tag 'BK_WEEKLY_FULL.${DATE}'format 'BK_WEEKLY_FULL_%d_%T_%U_%s'include current controlfile;sql 'alter system archive log current';backup archivelog allfilesperset 1tag 'BK_WEEKLY_ARCH.${DATE}'format 'BK_WEEKLY_ARCH_%d_%T_%U_%s';backup spfiletag 'BK_WEEKLY_SPFILE.${DATE}'format 'BK_WEEKLY_SPFILE_%d_%T_%U_%s';backup current controlfiletag 'BK_WEEKLY_CTRL.${DATE}'format 'BK_WEEKLY_CTRL_%d_%T_%U_%s';crosscheck backup;
delete noprompt expired backup;
delete noprompt obsolete;release channel ch00;
release channel ch01;
release channel ch02;
release channel ch03;
}list backup summary;EOF# ---------------------------------------------------------------
# end
# ---------------------------------------------------------------echo -e "\n****** Rman Full Backup Finished On `date +'%F %T'` ******\n" >> ${RMAN_LOG_FILE}exit 0

脚本赋予执行权限

$ chmod +x rman_orcl_full_weekly.sh

3.3 脚本试运行

oracle用户进入脚本目录执行:

$ cd /u01/app/oracle/rman/src
$ ./rman_orcl_full_weekly.sh

image.png

4 归档备份脚本部署

4.1 脚本说明

4.2 编辑脚本

oracle用户进入脚本目录,创建并编辑脚本:

$ cd /u01/app/oracle/rman/src
$ vi rman_orcl_arch_daily.sh

脚本内容如下:

#!/bin/bashif [ -f $HOME/.bash_profile ];
thenexport ORAENV_ASK=NO. $HOME/.bash_profile
fi# ---------------------------------------------------------------
# environment variables
# ---------------------------------------------------------------
export ORACLE_HOME=/u01/app/oracle/product/11.2/db_1
export ORACLE_SID=orcl
DATE=`date +'%Y%m%d%H'`RMANBASE=/u01/app/oracle/rman
SCRIPTDIR=${RMANBASE}/src
LOGDIR=${RMANBASE}/log
CTLDIR=${RMANBASE}/ctlRMAN_LOG_FILE=${LOGDIR}/${DATE}_${ORACLE_SID}_RMAN_ARCH.log# ---------------------------------------------------------------
# begin
# ---------------------------------------------------------------echo 'Run Script' $0 >> ${RMAN_LOG_FILE}
echo -e "\n****** Rman Archive Log Backup started on `date +'%F %T'` ******\n" >> ${RMAN_LOG_FILE}# ---------------------------------------------------------------
# rman archive log backup
# ---------------------------------------------------------------rman target / msglog ${RMAN_LOG_FILE} append << EOF
run {
allocate channel ch00 type disk;
allocate channel ch01 type disk;
allocate channel ch02 type disk;
allocate channel ch03 type disk;sql 'alter system archive log current';backup archivelog allfilesperset 1tag 'BK_DAILY_ARCH.${DATE}'format 'BK_DAILY_ARCH_%d_%T_%U_%s';crosscheck archivelog all;
delete noprompt archivelog all completed before 'sysdate-1';backup spfiletag 'BK_DAILY_SPFILE.${DATE}'format 'BK_DAILY_SPFILE_%d_%T_%U_%s';backup current controlfiletag 'BK_DAILY_CTRL.${DATE}'format 'BK_DAILY_CTRL_%d_%T_%U_%s';crosscheck backup;
delete noprompt expired backup;
delete noprompt obsolete;release channel ch00;
release channel ch01;
release channel ch02;
release channel ch03;
}list backup summary;EOF# ---------------------------------------------------------------
# end
# ---------------------------------------------------------------echo -e "\n****** Rman Archive Log Backup Finished On `date +'%F %T'` ******\n" >> ${RMAN_LOG_FILE}exit 0

脚本赋予执行权限:

$ chmod +x rman_orcl_arch_daily.sh

4.3 脚本试运行

oracle用户进入脚本目录执行:

$ cd /u01/app/oracle/rman/src
$ ./rman_orcl_arch_daily.sh

image.png

5 备份检查

5.1 备份日志检查

查看日志时,如何判断备份是成功的?

方法是,检查日志文件最后 List of Backups 部分,如果控制文件备份成功了,那么可以确定此次备份就是成功的。

因为在备份脚本中,备份操作都放在run{}里,只有当前的操作成功了,才可以继续执行后续的操作。而控制文件又是最后备份的,因此,控制文件备份成功,则说明前面的备份也是成功的,反之亦然。

一、查看全备日志

进入日志目录,查看最新的全备日志文件:

$ cd /u01/app/oracle/rman/log
$ ls -lth ^C
$ tail -50 2024092609_orcl_RMAN_FULL.log

image.png

二、查看归档备份日志

进入日志目录,查看最新的归档备份日志文件:

$ cd /u01/app/oracle/rman/log
$ ls -lth ^C
$ tail -50 2024092609_orcl_RMAN_ARCH.log

image.png

5.2 备份集检查

判断备份完整行的结果也是和看日志的方法一样,检查有没有控制文件备份集。

登录rman工具,命令查看备份集:

$ rman target /
RMAN> list backup summary;

image.png

5.3 查看视图

也可以通过数据库自带的视图v$rman_status查看备份情况,比较直观。

oracle用户登录数据库实例:

# su - oracle
$ sqlplus / as sysdba

输入下列sql脚本查看备份情况:

set lines 200
col Type_LV for a15
select *from (SELECT A.RECID BACKUP_SET,--A.SET_STAMP,DECODE(B.INCREMENTAL_LEVEL,'',DECODE(BACKUP_TYPE, 'L', 'Archivelog', 'Full'),1,'Incr-1级',0,'Incr-0级',B.INCREMENTAL_LEVEL) Type_LV,B.CONTROLFILE_INCLUDED INCLUDED_CTL,DECODE(A.STATUS,'A','AVAILABLE','D','DELETED','X','EXPIRED','ERROR') STATUS,A.DEVICE_TYPE Device_Type,to_char(A.START_TIME, 'yyyy-mm-dd hh24:mi:ss') Start_Time,to_char(A.COMPLETION_TIME, 'yyyy-mm-dd hh24:mi:ss') Completion_Time,A.ELAPSED_SECONDS Elapsed_Seconds,A.BYTES / 1024 / 1024 / 1024 "Size(GB)",A.COMPRESSED,A.TAG Tag--,A.HANDLE PathFROM GV$BACKUP_PIECE A, GV$BACKUP_SET BWHERE A.SET_STAMP = B.SET_STAMPAND A.DELETED = 'NO'ORDER BY A.COMPLETION_TIME DESC)where rownum <= 20;

image.png

6 配置定时任务

通常来说全备一周一次,归档每天一次。如果是核心系统,可以频繁一点,比如全备一周两次,归档每天几次。

本文就按照常规情况制定备份计划:

  • 全备:每周一次,周六执行,时间为2点;
  • 归档备份:每天一次,周一、二、三、四、五、七执行,时间为2点。

根据以上要求,使用oracle用户配置定时任务:

$ su - oracle
$ crontab -e

添加以下内容:

# --------------------------------------------------------------------
# Rman Backup
# --------------------------------------------------------------------
0 2 * * 6     sh /u01/app/oracle/rman/src/rman_orcl_full_weekly.sh >/dev/null 2>&1
0 2 * * 1-5,7 sh /u01/app/oracle/rman/src/rman_orcl_arch_daily.sh >/dev/null 2>&1

7 结语

至此,一套完善的RMAN备份脚本部署完成,能够应付绝大部分的备份恢复场景,可以确保在发生故障后,备份恢复数据不会丢失。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/432797.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony(鸿蒙南向)——平台驱动指南【MIPI CSI】

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ 持续更新中…… 概述 功能简介 CSI&#xff08;Camera Serial Interface&#xf…

JavaScript 学习

一、输出 为方便调试可以输出内容&#xff0c;但是用户是看不到的。要在开发者模式中看。 console . log ( "Hello" )&#xff1b; 二、外部文件引用 可以直接在html中写JS <head> <meta charset"utf-8"> <script> console.log("he…

Java面试题之JVM20问

1、说说 JVM 内存区域 这张图就是一个 JVM 运行时数据图&#xff0c;「紫色区域代表是线程共享的区域」&#xff0c;JAVA 程序在运行的过程中会把他管理的内存划分为若干个不同的数据区域&#xff0c;「每一块儿的数据区域所负责的功能都是不同的&#xff0c;他们也有不同的创建…

MAGICORE:基于多代理迭代的粗到细精炼框架,提升大语言模型推理质量

大语言模型(LLM)的推理能力可以通过测试时聚合策略来改进,即为每个问题生成多个样本并对它们进行聚合以找到更好的答案。这些方法往往会达到饱和点,超过这个点后额外的样本不会带来更多收益。精炼(refinement)提供了另一种选择,它使用模型生成的反馈不仅采样更多解决方案,还提高…

使用离火插件yoloV8数据标注,模型训练

1. 启动 2.相关配置 2.1 data.yaml path: D:/yolo-tool/yaunshen-yolov8/YOLOv8ys/YOLOv8-CUDA10.2/1/datasets/ceshi001 train: images val: images names: [蔡徐坤,篮球] 2.2 cfg.yaml # Ultralytics YOLOv8, GPL-3.0 license # Default training settings and hyp…

解读 Story Protocol:IP 与区块链的潜力与障碍

撰文&#xff1a;100y.eth 编译&#xff1a;J1N&#xff0c;Techub News 8 月&#xff0c;据 The Block 报道&#xff0c;专注于知识产权&#xff08;IP&#xff09;的区块链 Story 宣布完成 a16z Crypto 领投 8000 万美元 B 轮融资&#xff0c;参投方包括 Polychain Capital&…

AI搜索软件哪个好,AI搜索引擎工具分享

随着AI技术的发展&#xff0c;AI搜索引擎工具正逐渐成为我们信息获取的重要方法。下面小编就来和大家分享一些好用的AI搜索引擎软件&#xff0c;感兴趣的同学可以逐个使用体验一下。因为每个AI搜索引擎工具不同&#xff0c;建议大家搜索的时候可以多个工具搜索&#xff0c;然后…

Java笔试面试题AI答之设计模式(1)

文章目录 1. 简述什么是设计模式 &#xff1f;2. 叙述常见Java设计模式分类 &#xff1f;3. Java 设计模式的六大原则 &#xff1f;4. 简述对 MVC 的理解&#xff0c; MVC 有什么优缺点&#xff1f;MVC 的三个核心部分&#xff1a;MVC 的优点&#xff1a;MVC 的缺点&#xff1a…

已存在的Python项目使用依赖管理工具UV

1. 文档 uv文档 2. 如何转换 初始化 uv initrequirements.txt转换成pyproject.toml uv add $(cat requirements.txt)删除requirements.txt 如果更新pyproject.toml之后&#xff0c;使用命令 uv sync替换项目环境 如果有库没有加入依赖&#xff0c;自己手动加一下&am…

助力降本增效,ByteHouse打造新一代云原生数据仓库

随着数据量的爆炸式增长、企业上云速度加快以及数据实时性需求加强&#xff0c;云原生数仓市场迎来了快速发展机遇。 据 IDC、Gartner 研究机构数据显示&#xff0c;到 2025 年&#xff0c;企业 50% 数据预计为云存储&#xff0c;75% 数据库都将运行在云上&#xff0c;全球数据…

【Kubernetes】日志平台EFK+Logstash+Kafka【实战】

一&#xff0c;环境准备 &#xff08;1&#xff09;下载镜像包&#xff08;共3个&#xff09;&#xff1a; elasticsearch-7-12-1.tar.gz fluentd-containerd.tar.gz kibana-7-12-1.tar.gz &#xff08;2&#xff09;在node节点导入镜像&#xff1a; ctr -nk8s.io images i…

webpack使用

一、简介 概述 本次使用webpack4进行构建打包 二、webpack 安装webpack、webpack-cli npm install webpack4.2.0 webpack-cli4.2.0 -D 三、loader 加载器概述 raw-loader&#xff1a;加载文件原始内容&#xff08;utf-8&#xff09; file-loader&#xff1a;把文件输出…

CentOS 7 中安装 docker 环境

作者&#xff1a;程序那点事儿 日期&#xff1a;2023/02/15 02:31 官网地址 官网文档 docker三种网络模式 Docker CE 支持 64 位版本 CentOS 7&#xff0c;并且要求内核版本不低于 3.10&#xff0c; CentOS 7 满足最低内核的要求。 Docker 分为 CE 和 EE 两大版本。CE 即社区…

蓝桥杯1.小蓝的漆房

样例输入 2 5 2 1 1 2 2 1 6 2 1 2 2 3 3 3样例输出 1 2 import math import os import sys tint(input())#执行的次数 for j in range(t):n,kmap(int,input().split())#n为房间数 k为一次能涂的个数alist(map(int,input().split()))#以列表的形式存放房间的颜色maxvaluemath…

81、Python之鸭子类型:从魔法函数看对象的字符串呈现

引言 前面已经介绍了鸭子类型的概念&#xff0c;以及Python中支撑鸭子类型理念的“魔法函数”的体系。Python中的魔法函数分为几大类&#xff0c;本文我们首先从最简单的自定义类型的字符串呈现来切入&#xff0c;逐步理解并掌握Python中的魔法函数的完整架构。 本文的主要内…

玩转指针(3)

一、字符指针变量 字符指针变量&#xff08;如char* p&#xff09;的两种赋值方式 ①将字符类型地址赋值给字符指针变量 int main() {char a w;char* p &a;*p m;return 0; }②将常量字符串赋值给字符指针变量 常量字符串的介绍&#xff1a;用" "引起来的就…

以Flask为基础的虾皮Shopee“曲线滑块验证码”识别系统部署

以Flask为基础的虾皮Shopee“曲线滑块验证码”识别系统部署 一、验证码类型二、简介三、Flask应用 一、验证码类型 验证码类型&#xff1a;此类验证码存在两个难点&#xff0c;一是有右侧有两个凹槽&#xff0c;二是滑块的运动轨迹不是直线的&#xff0c;而是沿着曲线走的&…

STM32通过HAL库编码方式,在烧写一次程序后,单片机在仿真器上识别不到

在将项目从裸机移植到rtt过程中&#xff0c;总体调试跑不通ADC&#xff0c;进行了单独调试&#xff0c;新程序烧写进单片机后&#xff0c;仿真器再也识别不到单片机。一遍遍检查后发现HAL库没有配置完全。 SYS需要设置成 Serial Wire&#xff0c;忘记设置就成了No Debug,写这么…

基于nodejs+vue的水产品销售管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目…

如何在 macOS(MacBook Pro、Air 和 iMac)上恢复未保存的 Word 文档

Microsoft Word 在许多用户中很受欢迎&#xff0c;并且有多种用途。无论是为学校写论文、在办公室写报告还是其他许多事情。但是不保存文档并丢失数据可能是您可能面临的最可怕的噩梦。但是&#xff0c;也有几种方法可以在 macOS 上恢复未保存的 Word 文档。 用户在 Windows P…