利用SHELL脚本来验证Oracle数据库RMAN备份集的有效性

编辑手记:一切都有可能而且将会发生故障。只有未雨绸缪才能防患未然。

作者简介:赵全文

就职于太极计算机股份有限公司,在 中央电化教育馆 做Oracle DBA的驻场运维工作。

作为一个DBA,要时刻记得,故障是绝对会发生的,只是迟早的问题。

我们生产环境的Oracle数据库都做了RMAN备份,是采用了一周的RMAN备份保留策略;除了使用RMAN备份以外,我们还使用了爱数(Eisoo)备份软件来进行备份,可以说是做到了有备无患。可是,如果有一天,Oracle数据库由于主机层面硬件原因或是数据库层面的原因不能对外提供高可用服务的时候,假设数据丢了一大部分,我们只有用RMAN备份来进行恢复,再如果发现,RMAN备份失效了,那就往地缝里钻和哭晕在厕所都于事无补了。

为了防止这一幕的出现,就需要对Oracle数据库RMAN备份集的有效性进行验证。为此,我专门写了一个SHELL脚本用来验证RMAN备份集的有效性,将该脚本文件放在了crontab的计划任务里,让其在每天晚上21点自动运行,目的是验证前一天生成的RMAN备份集的有效性。

现在,用线上的一套Oracle数据库生产环境,来演示操作。

首先,查看最近的一次RMAN全备,如下图所示,

接下来,查看一下生成的校验RMAN备份集有效性的LOG文件,见下图,

我们就以查看2017年3月3日生成的LOG文件为例,下面是执行SHELL脚本验证的结果,见下图所示,

截图一,

我们发现,上面首先校验的是3月2日生成的增量备份里的归档日志备份集。

截图二

紧接着,是校验增量1级备份生成的备份集和最后手动归档以及备份的归档日志备份集。

截图三

由于在RMAN的参数设置中开启了控制文件的自动备份功能,所以最后备份的是控制文件,那么最后校验的也是控制文件!

俗话说的好,“工欲善其事,必先利其器”!最后着重介绍一下,rman_validate_v2.sh 这个验证RMAN备份集有效性的SHELL脚本的具体内容,

由于脚本内容过多,下面分三个部分来说明,见下图。

截图一:

依次解释一下,几个红色方框标注的地方

  • 个人简介,包括姓名,Emai邮箱,技术博客网址;
  • SHELL脚本文件名;
  • 最近修改日期;
  • 该SH脚本使用的注意事项,当然是先确保在测试环境上测试通过以后,在放到生产环境中使用啦。

截图2

图2,有3个红色方框,

  • 方框1是定义在脚本中要使用的SHELL外部命令所在的绝对路径,每种Linux操作系统上所在的路径有可能不同,尽量要使用“which 想要使用的命令名”来查找一下,然后写到上面,通常把要使用的都要写上去;
  • 方框2是定义了一些有关路径的字符串变量和普通字符串变量以及SHELL命令用一对反引号(键盘上ESC键下面和数字1键左边的那个键)括起来的字符串变量(注意:只有用反引号括起来才能生成SHELL命令的执行结果);
  • 方框3是使用SQLPLUS命令连接到Oracle数据库以后,通过查询视图V$BACKUP_SET_DETAILS来找出前一天生成的RMAN备份集当中所有的BS_KEY值,然后保存到一个字符串变量BSKEY_LIST。

截图3,

图3有2个红色方框需要特别说明:

  • 方框1是通过强大AWK命令将字符串变量BSKEY_LIST的值“6046 6047 6048 6049 6050 6051 6052”的中间加一个逗号(所以我把方框1的字符串变量命名为BSKEY_LIST_WITH_COMMA,意即带逗号的BSKEY_LIST),形如这种格式,“6046,6047,6048,6049,6050,6051,6052”;
  • 方框2是在最后进入RMAN命令行,校验RMAN备份集有效性的语句,validatebackupset 后面紧跟的就是带逗号的BS_KEY值列表,形如这种格式,“validatebackupset 6046,6047,6048,6049,6050,6051,6052 check logical;”其实,也可以使用一个FOR循环来将字符串变量BSKEY_LIST的值一个一个读出,然后执行一次validate backupset 6046 check logical;再取一个值,再执行一次validatebackupset 6047 check logical;直到都把字符变量BSKEY_LIST的值取完为止,那样的话,就不用定义前面那个字符串变量BSKEY_LIST_WITH_COMMA了。看个人喜好,我觉得带逗号这种方式,个人比较喜欢和推荐使用。

我把rman_validate_v2.sh这个脚本放在了github上,网址为https://github.com/guestart/rman_validate/blob/master/rman_validate_v2.sh,如果需要下载即可。(原文链接直达)

备份的重要性,再强调都不为过。

最后,推荐我们以前发过的一篇文章作为勉励。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-03-14

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏安富莱嵌入式技术分享

【安富莱】【RL-TCPnet网络教程】第10章 RL-TCPnet网络协议栈移植(FreeRTOS)

本章教程为大家讲解RL-TCPnet网络协议栈的FreeRTOS操作系统移植方式,学习了第6章讲解的底层驱动接口函数之后,移植就比较容易了,主要是添加库文件、配...

982
来自专栏数据库

替代SE16N的超强悍SE16H

文 | 大话SAP 又到了天气转冷,懒得出门,窝在家里学习新知识的季节。 也许你早就对SE11/SE16/SE16N/SQVI等T-code熟得不能再熟,不过,...

30310
来自专栏xcywt

《Linux命令行与shell脚本编程大全》23章24章

第二十三章 使用其他shell bash shell是linux发行版中最广泛使用的shell。但是它并不是唯一的选择,还有其他的shell可以供你选择。 23...

2357
来自专栏java达人

Latke 快速上手指南

欢迎投稿 黑客派作品 Latke 在设计原理上非常类似 Spring,是 Spring 的极简版,该文档适合 Java Web 应用 框架初学者 以及Latke...

2476
来自专栏实战docker

Docker下的Kafka学习之三:集群环境下的java开发

在上一章《Docker下的Kafka学习之二:搭建集群环境》中我们学会了搭建kafka集群环境,今天我们来实战集群环境下的用java发送和消费kafka的消息;...

2365
来自专栏开发之途

Android IPC机制(1)-序列化机制

1435
来自专栏杨建荣的学习笔记

oracle的TAF浅析 (r6笔记第37天)

在使用rac的时候,有几个很闪亮的使用特性,一个就是load balance,这块毋庸置疑,确实做了很大的改进,从10g版本开始的多个vip地址的load b...

3835
来自专栏杨建荣的学习笔记

一个简单的MySQL数据迁移示例

因为服务器迁移,目前一套硬件老化的MySQL主从服务器都需要替换为新服务器,总体评估了一下,在不改变版本的情况下,采用了较新的5.6子版本。就是如下图所...

3567
来自专栏三丰SanFeng

Apache thrift - 使用,内部实现及构建一个可扩展的RPC框架

本文首先介绍了什么是Apache Thrift,接着介绍了Thrift的安装部署及如何利用Thrift来实现一个简单的RPC应用,并简单的探究了一下Thrift...

6319
来自专栏FreeBuf

利用Winrm.vbs绕过白名单限制执行任意代码

winrm.vbs(一个位于system32目录下的具有Windows签名的脚本文件)可以被用来调用用户定义的XSL文件,从而导致任意的、没有签名的代码执行。当...

1814

扫码关注云+社区