RESETLOG之后数据文件丢失的RMAN恢复测试

2023-11-18

RESETLOG之后数据文件丢失的RMAN恢复测试

一、场景

在T0时间点做了RMAN全备,随后在T1时间点由于误操作将T0表truncate。在T2时间点通过RMAN的不完全恢复,将数据库恢复到T1时间点(truncate之前),resetlog之后没有做RMAN的全备。恢复数据库之后,创建了3张业务表T1、T2、T3,由于介质故障在T4时间点所有的数据文件均已丢失(模拟删除),然而redo、归档日志文件、控制文件都在,可以通过resetlog之前的备份文件执行完全恢复。
在这里插入图片描述

二、模拟步骤

1、T0时间点admin用户下创建表T0

conn admin/admin123
create table t0 (id number,name varchar2(10));
insert into t0 values(1,'a');
insert into t0 values(2,'b');
insert into t0 values(3,'c');
insert into t0 values(4,'d');
insert into t0 values(5,'e');
commit;
alter system switch logfile;
/
/
/
SQL> select * from t0;

        ID NAME
---------- ------------------------------
         1 a
         2 b
         3 c
         4 d
         5 e

2、对数据库做RMAN全备

RMAN> backup database format '/u01/rman_orcl/fulldb_%d_%T_%U.bak';

3、记录下当前全备的时间

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') currtime from dual;
2018/08/09 16:09:19

4、在T1时间点truncate表T0,模拟误操作

SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') currtime from dual;

CURRTIME
---------------------------------------------------------
2018-08-09 16:33:40

truncate table t0;
Table truncated.

select * from t0;
no rows selected

5、在T2时间点通过RMAN不完全恢复到T1时间点(truncate之前)

SQL> shutdown immediate;
startup mount;

还原数据文件

RMAN> restore database until time "to_date('2018-08-09 16:33:40','yyyy-mm-dd hh24:mi:ss')";
Starting restore at 2018/08/09 16:38:16
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=386 device type=DISK
flashing back control file to SCN 3009005

channel ORA_DISK_1: starting datafile backup set restore
channel ORA_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_DISK_1: restoring datafile 00001 to /u01/app/oracle/oradata/orcl/system01.dbf
channel ORA_DISK_1: restoring datafile 00002 to /u01/app/oracle/oradata/orcl/sysaux01.dbf
channel ORA_DISK_1: restoring datafile 00003 to /u01/app/oracle/oradata/orcl/undotbs01.dbf
channel ORA_DISK_1: restoring datafile 00004 to /u01/app/oracle/oradata/orcl/users01.dbf
channel ORA_DISK_1: restoring datafile 00005 to /u01/app/oracle/oradata/orcl/secure.dbf
channel ORA_DISK_1: restoring datafile 00006 to /u01/app/oracle/oradata/orcl/tbs.dbf
channel ORA_DISK_1: restoring datafile 00007 to /u01/app/oracle/oradata/orcl/epoint9_9_3_3.dbf
channel ORA_DISK_1: restoring datafile 00008 to /u01/app/oracle/oradata/orcl/admin1.dbf
channel ORA_DISK_1: restoring datafile 00010 to /u01/app/oracle/oradata/orcl/admin2.dbf
channel ORA_DISK_1: reading from backup piece /u01/rman_orcl/fulldb_ORCL_20180809_6rta4q4v_1_1.bak
channel ORA_DISK_1: piece handle=/u01/rman_orcl/fulldb_ORCL_20180809_6rta4q4v_1_1.bak tag=TAG20180809T160903
channel ORA_DISK_1: restored backup piece 1
channel ORA_DISK_1: restore complete, elapsed time: 00:00:25
Finished restore at 2018/08/09 16:38:42

恢复应用日志

RMAN> recover database until time "to_date('2018-08-09 16:33:40','yyyy-mm-dd hh24:mi:ss')";
Starting recover at 2018/08/09 16:39:17
using channel ORA_DISK_1

starting media recovery

archived log for thread 1 with sequence 16 is already on disk as file /u01/arch/1_16_983525552.dbf
archived log for thread 1 with sequence 17 is already on disk as file /u01/arch/1_17_983525552.dbf
archived log for thread 1 with sequence 18 is already on disk as file /u01/arch/1_18_983525552.dbf
archived log for thread 1 with sequence 19 is already on disk as file /u01/arch/1_19_983525552.dbf
archived log for thread 1 with sequence 20 is already on disk as file /u01/arch/1_20_983525552.dbf
archived log for thread 1 with sequence 21 is already on disk as file /u01/arch/1_21_983525552.dbf
archived log for thread 1 with sequence 22 is already on disk as file /u01/app/oracle/oradata/orcl/redo03.log
archived log for thread 1 with sequence 23 is already on disk as file /u01/app/oracle/oradata/orcl/redo01.log
archived log for thread 1 with sequence 24 is already on disk as file /u01/app/oracle/oradata/orcl/redo02.log
archived log file name=/u01/arch/1_16_983525552.dbf thread=1 sequence=16
archived log file name=/u01/arch/1_17_983525552.dbf thread=1 sequence=17
archived log file name=/u01/arch/1_18_983525552.dbf thread=1 sequence=18
archived log file name=/u01/arch/1_19_983525552.dbf thread=1 sequence=19
archived log file name=/u01/arch/1_20_983525552.dbf thread=1 sequence=20
archived log file name=/u01/arch/1_21_983525552.dbf thread=1 sequence=21
media recovery complete, elapsed time: 00:00:01
Finished recover at 2018/08/09 16:39:20

6、在T3时间点resetlogs,日志序列号被重置

alter database open resetlogs;
SQL> archive log list;
Database log mode              Archive Mode
Automatic archival             Enabled
Archive destination            /u01/arch
Oldest online log sequence     1
Next log sequence to archive   2
Current log sequence           2

7、恢复数据库之后查看T0表

SQL> select * from admin.t0;

        ID NAME
---------- ------------------------------
         1 a
         2 b
         3 c
         4 d
         5 e

已恢复表数据

8、随后admin下创建3张表

SQL> conn admin/admin123
create table t1 as select * from dba_users;
create table t2 as select * from dba_users;
create table t3 as select * from dba_users;

记录下此时时间点

SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') currtime from dual;

CURRTIME
---------------------------------------------------------
2018-08-09 16:44:19

9、在T4时间点删除所有数据文件(模拟介质故障),日志文件、归档日志、控制文件都在

SQL> select name from v$datafile;
NAME
----------------------------------------------
/u01/app/oracle/oradata/orcl/system01.dbf
/u01/app/oracle/oradata/orcl/sysaux01.dbf
/u01/app/oracle/oradata/orcl/undotbs01.dbf
/u01/app/oracle/oradata/orcl/users01.dbf
/u01/app/oracle/oradata/orcl/secure.dbf
/u01/app/oracle/oradata/orcl/tbs.dbf
/u01/app/oracle/oradata/orcl/epoint9_9_3_3.dbf
/u01/app/oracle/oradata/orcl/admin1.dbf
/u01/app/oracle/oradata/orcl/admin2.dbf

9 rows selected.
SQL> alter system switch logfile;

System altered.

SQL> /

System altered.

SQL> /

System altered.

SQL> /

System altered.

记录下此时日志序列号

SQL> archive log list;
Database log mode              Archive Mode
Automatic archival             Enabled
Archive destination            /u01/arch
Oldest online log sequence     3
Next log sequence to archive   5
Current log sequence           5
SQL> shutdown immediate;

删除所有数据文件

[oracle@gs orcl]$ rm -rf *.dbf

10、通过RMAN完全恢复到T4故障点之前

[oracle@gs orcl]$ rman target /
RMAN> startup mount;
RMAN> restore database;
Starting restore at 2018/08/09 16:58:24
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=5 device type=DISK

channel ORA_DISK_1: starting datafile backup set restore
channel ORA_DISK_1: specifying datafile(s) to restore from backup set
channel ORA_DISK_1: restoring datafile 00001 to /u01/app/oracle/oradata/orcl/system01.dbf
channel ORA_DISK_1: restoring datafile 00002 to /u01/app/oracle/oradata/orcl/sysaux01.dbf
channel ORA_DISK_1: restoring datafile 00003 to /u01/app/oracle/oradata/orcl/undotbs01.dbf
channel ORA_DISK_1: restoring datafile 00004 to /u01/app/oracle/oradata/orcl/users01.dbf
channel ORA_DISK_1: restoring datafile 00005 to /u01/app/oracle/oradata/orcl/secure.dbf
channel ORA_DISK_1: restoring datafile 00006 to /u01/app/oracle/oradata/orcl/tbs.dbf
channel ORA_DISK_1: restoring datafile 00007 to /u01/app/oracle/oradata/orcl/epoint9_9_3_3.dbf
channel ORA_DISK_1: restoring datafile 00008 to /u01/app/oracle/oradata/orcl/admin1.dbf
channel ORA_DISK_1: restoring datafile 00010 to /u01/app/oracle/oradata/orcl/admin2.dbf
channel ORA_DISK_1: reading from backup piece /u01/rman_orcl/fulldb_ORCL_20180809_6rta4q4v_1_1.bak
channel ORA_DISK_1: piece handle=/u01/rman_orcl/fulldb_ORCL_20180809_6rta4q4v_1_1.bak tag=TAG20180809T160903
channel ORA_DISK_1: restored backup piece 1
channel ORA_DISK_1: restore complete, elapsed time: 00:00:25
Finished restore at 2018/08/09 16:58:50
RMAN> recover database;
Starting recover at 2018/08/09 16:58:59
using channel ORA_DISK_1

starting media recovery

archived log for thread 1 with sequence 24 is already on disk as file /u01/arch/1_24_983525552.dbf
archived log for thread 1 with sequence 1 is already on disk as file /u01/arch/1_1_983724050.dbf
archived log for thread 1 with sequence 2 is already on disk as file /u01/arch/1_2_983724050.dbf
archived log for thread 1 with sequence 3 is already on disk as file /u01/arch/1_3_983724050.dbf
archived log for thread 1 with sequence 4 is already on disk as file /u01/arch/1_4_983724050.dbf
archived log file name=/u01/arch/1_24_983525552.dbf thread=1 sequence=24
archived log file name=/u01/arch/1_1_983724050.dbf thread=1 sequence=1
archived log file name=/u01/arch/1_2_983724050.dbf thread=1 sequence=2
media recovery complete, elapsed time: 00:00:01
Finished recover at 2018/08/09 16:59:01

11、恢复之后打开数据库

RMAN> alter database open;

database opened

查看此时序列号还是故障之前,保持完整

SQL> archive log list;
Database log mode              Archive Mode
Automatic archival             Enabled
Archive destination            /u01/arch
Oldest online log sequence     3
Next log sequence to archive   5
Current log sequence           5

12、查看在发生故障之前创建的3张表

SQL> select count(*) from t1;

  COUNT(*)
----------
        32

SQL> select count(*) from t2;

  COUNT(*)
----------
        32


SQL> select count(*) from t3;

  COUNT(*)
----------
        32

SQL> select count(*) from t0;

  COUNT(*)
----------
         5

SQL> select * from t0;

        ID NAME
---------- ------------------------------
         1 a
         2 b
         3 c
         4 d
         5 e
         
数据均准确。

结论:resetlog之后,如果数据文件意外损坏或者误删。只要redo、归档文件、控制文件还在,可以拿resetlog之前的备份执行完全恢复。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

RESETLOG之后数据文件丢失的RMAN恢复测试 的相关文章

  • CH10-HarmonyOS原子化服务

    文章目录 前言 目标 原子化服务定义 原子化服务特性 原子化服务体验 服务中心 原子化服务流转 原子化服务分享 原子化开发基础 开发总体要求 服务卡片定义 运作机制 卡片提供方主要回调函数 JS卡片语法基础 原子化服务开发进阶 卡片结构目录
  • 实验吧-密码学-奇怪的短信(九键密码)

    短信里的一段密文 335321414374744361715332 一般来说是用手机接收短信的 于是可能是手机上的九键 将密文两个两个分隔开 33 53 21 41 43 74 74 43 61 71 53 32 然后对应着拼音九键来找出对
  • Android开发 关于避免切换主题时免闪屏的几种方式

    Android开发 关于避免切换主题时闪屏的几种方式 在activity中调用setTheme来切换夜间模式的方法可能大家有看过相关的文章了 但是调用setTheme设置的主题后界面并没有变化 这时需要调用activity的recreate
  • RAID 磁盘状态为foreign,怎么变成ready

    我们在关掉电源 插入三块硬盘 打开电源 这时候 首先启动服务器 出现 Press
  • Eclipse重命名Package,出现的四个选项的意思。

    1 update references 更新参考 2 Rename subpackages 重命名子包 3 Update textual occurrences in comments and strings forces preview
  • 51单片机SCT15数码管4321断灭长灭程序

    include
  • 第七章 yaml格式

    一 简单说明 yaml是一个可读性高 用来表达数据序列的格式 YAML 的意思其实是 仍是一种标记语言 但为了强调这种语言以数据做为中心 而不是以标记语言为重点 二 基本语法 缩进时不允许使用Tab键 只允许使用空格缩进的空格 数目不重要
  • 好分数阅卷3.0_网上阅卷系统是什么

    什么是网上阅卷系统 网上阅卷系统简称在线阅卷或阅卷系统 是一套集电子光学扫描技术和计算机网络技术于一体的纸答题卡电子处理的一套软硬件结合的现代计算机系统 系统特点及简介它主要实现了答题卡模板的智能化生产 由计算机自动对考生填写选择题段信息点
  • 追根究底,剖析MFC六大关键技术(1)

    题外话 我并不认为MFC减轻了程序员们的负担 MFC出现的目的虽然似乎是为了让程序员不用懂得太多就可以进行视窗编程 但本人在MFC里徘徊了很久很久 因为那时没有书本详细介绍MFC的原理 毫无收获 可能朋友们会说 怎么一定要了解MFC的具体呢
  • HBuilder X 上传git仓库

    首先安装git插件 HBuilder的左上方点击工具 点击插件安装 gt 安装新插件 gt 下滑找到 git 进行安装 安装easy git源码管理 HBuilder的左上方点击工具 点击插件安装 gt 安装新插件 gt 前往插件市场安装
  • K8s Liveness/Readiness/Startup 探针机制

    官方参考文档 目录 前言 一 默认健康检测 1 1 restartPolicy 1 2 测试案例 二 Liveness 三 Readiness 四 Startup 前言 玩过 Docker Swarm 的应该都知道 有一种功能叫自愈功能 当
  • 4.9-4.10 矩阵乘法的性质 & 矩阵的幂运算 & 矩阵的转置及其性质

    矩阵乘法的性质 矩阵的乘法不遵守交换律 矩阵乘法遵守结合律 分配律 对于任意r行c列的矩阵A 存在c行x列的矩阵O 满足 A Ocx Orx 对于任意r行c列的矩阵A 存在x行r列的矩阵O 满足 Oxr A Oxc 证明思路 A B C A

随机推荐

  • 3.二进制数的应用、逻辑学及逻辑门

    由前面的例子中我们讲了很多设备 比如手电筒 继电器 以及两个编码 莫尔斯编码和布莱叶盲文 这些和我们熟知的二进制数有着很大的联系 二进制数我们已经很了解了 接下来举几个例子 1 胶卷的好坏判定 我们把胶卷拉开 会发现有12个方格 是由银色和
  • Keil(MDK-ARM-STM32)系列教程(四)工程目标选项配置(Ⅱ)

    写在前面 本文接着上一篇文章 工程目标选项配置 进行讲述工程目标选项中后五项的配置 也就是C C Asm Linker Debug Utilities这五项配置的具体内容 对于工程目标选项中的C C 选项 不管是初学者 还是资深的软件工程师
  • memcach redis的理解 和有点

    Memcach 是一种缓存技术 在一定的时间内将动态页面经过解析之后保存发到文件中国 下次访问时动态网页就直接调用这个文件 而不必再重新访问数据库 使用memcach 做缓存的好处是 提高网站的访问速度 减轻高并发是服务器的压力 优点 稳定
  • 对于一个程序员来说,电脑的内存需要多大?

    1 程序员电脑内存有多大内存够用足够了 纯写代码的编程对电脑要求不高 尤其对显卡几乎没有要求 一般编程可能开的任务窗口比较多 所以只要cpu和内存大点就可以了一般来说 处理器确实比显卡来得重要一些 因为我们的电脑中只配备了一块处理器 而处理
  • MEX 文件 ‘lsd.mexw64‘ 无效: 找不到指定的模块。问题解决方法

    问题描述 在跑MATLAB和C 混合编程的一个算法时 出现了如下错误 MEX 文件 C Project final code reference code lsd mexw64 无效 找不到指定的模块 如下图所示 原因分析 根据资料 1 的
  • windows安装cx_oracle的坑

    转自http rookiefly cn detail 69 作死小能手这两天闲着没事 把自己电脑重装了 然而重装过后配置开发环境踩了一些坑 这里把安装cx oracle遇到的坑记录下来 方便以后查看 使用pip安装出现的问题 命令 pip
  • linux下nc命令

    一 nc命令检测端口的用法 nc v w 10 IP z PORT v 显示指令执行过程 w lt 超时秒数 gt 设置等待连线的时间 u 表示使用UDP协议 z 使用0输入 输出模式 只在扫描通信端口时使用 例1 扫描指定的8080端口
  • 亚马逊云科技与百川智能发起AI黑客松,共探医疗健康和游戏娱乐领域的前沿应用

    8月31日 亚马逊云科技云创计划成员企业暨基础模型创业公司百川智能 率先通过了 生成式人工智能服务管理暂行办法 备案 即日起面向全社会开放服务 基础模型获准面向公众用户开放服务 意味着有机会基于大量真实用户的调用反馈建立模型迭代的飞轮 其效
  • Linux命令之远程连接ssh

    概述 ssh命令是openssh套件中的客户端连接工具 可以给予ssh加密协议实现安全的远程登录服务器 实现对服务器的远程管理 在脚本中该命令有着重要重要 可用于在远程服务器中执行命令 语法 ssh命令的基本语法如下 ssh 选项 参数 常
  • APP启动页隐私弹窗实现说明

    最近审核严禁 腾讯应用市场要求APP在启动页增加隐私政策和用户协议 用户从腾讯应用市场上下载APP 第一加载的时候弹窗 不然审核就不给过 样式大概如下 用户若点击不同意的时候 无法进入APP内部 下面把实现的代码贴上来 1 加个判断 其他应
  • java eclipse打不开_安装eclipse以后打不开,出现这个图

    方法1 将eclipse发送到桌面快捷方式 然后右键 属性 快捷方式 tab 目标 显示E dev enrionment eclipse eclipse exe 进行如下更改 E dev enrionment eclipse eclipse
  • 基于改进YoloV3卷积神经网络的番茄病虫害检测

    ABSTRACT 番茄在生长过程中受到各种病虫害的影响 如果控制不及时 就会导致减产甚至歉收 如何有效地控制病虫害 帮助菜农提高番茄的产量是非常重要的 而准确地识别病虫害是最重要的 与传统的模式识别方法相比 基于深度学习的病虫害识别方法可以
  • pycharm设置文件标头

    一 设置模板步骤 文件File 设置Settings 编辑器Editor File and Code Templates Python Script 里面设置模板 coding utf 8 Time DATE TIME 人生的事情并不是一帆
  • C++针对ZeroMQ库的选择

    介绍 ZeroMQ 也称为0MQ或 MQ 是一个高性能 低延迟的消息队列库 它为分布式和并发应用程序提供了简洁 高效的通信机制 它是一个开源的库 支持多种编程语言 包括C 和操作系统 ZeroMQ通过使用套接字抽象来实现消息传递 使得它易于
  • 计算机网络学习日记 把码元的振幅化为16个不同等级来传输-为什么要使用信道复用技术?

    奈氏准则 在宽带为W的低通信道中 若不考虑噪声影响 则马原传输的最高速率是2W 传输速率超过此上线 就会出现验证的码间串扰的问题 使接收端对码元的决判成为不可能 假定某信道收奈氏准则的限制最高码元速率为20000码元 秒 如果采用振幅调制
  • 如何使用CSS递归选择所有子元素?

    当元素是某个元素的子元素时 子选择器匹配 子选择器由两个或多个由 gt 分隔的选择器组成 也称为元素 gt 元素选择器 它选择特定父级的所有元素 语法如下 选择所有子元素 element gt element 如果子元素递归选择 则使用以下
  • Python_文件的代码格式

    导入模块 定义全局变量 定义类 定义函数 在代码的最下方 def main pass 根据 name 判断是否执行下方代码 if name main main
  • 图解十大经典机器学习算法入门

    通过本篇文章可以对机器学习的常用算法有个常识性的认识 没有代码 没有复杂的理论推导 就是图解一下 知道这些算法是什么 它们是怎么具体应用的 1 决策树 根据一些 feature 进行分类 每个节点提一个问题 通过判断 将数据分为两类 再继续
  • OPENCV手势识别抓取图片

    PENCV手势识别抓取图片 一位油管的小哥做的项目非常棒 照着写了一个 代码 注意 看好cvzone的版本 太新的版本中有个函数没有 如果找不到这个函数的时候请更换一下库的版本 import cv2 from cvzone HandTrac
  • RESETLOG之后数据文件丢失的RMAN恢复测试

    RESETLOG之后数据文件丢失的RMAN恢复测试 一 场景 在T0时间点做了RMAN全备 随后在T1时间点由于误操作将T0表truncate 在T2时间点通过RMAN的不完全恢复 将数据库恢复到T1时间点 truncate之前 reset