摘要

  本文主要介绍incarnation的由来,在rman恢复中的作用,以及相关rman恢复的注意事项。

概念说明

  从10g开始,incarnation被引入,用于跨越resetlogs进行恢复,由此可见,此概念在rman中可以找到相关使用轨迹。

  Resetlogs命令表示一个数据库逻辑生存期的结束和另一个数据库逻辑生存期的开始,Oracle把这个数据库逻辑生存期称为incarnation;每次使用resetlogs打开数据库,就会使incarnation + 1,也就是产生一个新的incarnation;如果想要恢复到之前incarnation的scn/time,就需要先恢复到之前的incarnation;

  下图来源官方文档,可以自行理解incarnation在 rman恢复的作用,其中灰色线是数据库rman恢复之后的运行路径。

  

实验环节

初识incarnation

  在rman中可以可以通过list incarnation命令查看当前数据库有多少化身,新创建的数据库默认只有1条记录,下面所示2条记录,代表数据库做过rman不完全恢复,即进行过alter database open resetlogs操作。

  

 [oracle@redhat3 ~]$ rman target /

 Recovery Manager: Release 11.2.0.4.0 - Production on Thu Jul 18 10:10:37 2019

 Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 connected to target database: TEST (DBID=2274480208, not open)

 RMAN> list incarnation;

 using target database control file instead of recovery catalog

 List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time
------- ------- -------- ---------------- --- ---------- ----------
1 1 TEST 2274480208 PARENT 4483656 11-JUL-19
2 2 TEST 2274480208 CURRENT 4504768 11-JUL-19

对数据库进行不完全恢复

  首先对数据库进行rman备份,此处不做过多说明。

  查看现有rman备份,可知数据文件6的scn为457020,即数据最小可指定恢复SCN号为457020,(实验一中会给出说明),最大可指定SCN号为归档文件的25号的4597382(下面会进行演示),所以指定SCN号恢复时,SCN区间应在457020-4597382之间。

 RMAN> list backup;

 List of Backup Sets
=================== BS Key Type LV Size Device Type Elapsed Time Completion Time
------- ---- -- ---------- ----------- ------------ ---------------
1 Full 237.04M DISK 00:01:08 18-JUL-19
BP Key: 1 Status: AVAILABLE Compressed: NO Tag: TAG20190718T093005
Piece Name: /u01/app/rmanbak/db_TEST_20190718_01u6uu0u_1
List of Datafiles in backup set 1
File LV Type Ckp SCN Ckp Time Name
---- -- ---- ---------- --------- ----
2 Full 4596984 18-JUL-19 /u01/app/oracle/oradata/test/sysaux01.dbf
4 Full 4596984 18-JUL-19 /u01/app/oracle/oradata/test/users01.dbf
7 Full 4596984 18-JUL-19 /u01/app/oracle/oradata/test/sde01.dbf BS Key Type LV Size Device Type Elapsed Time Completion Time
------- ---- -- ---------- ----------- ------------ ---------------
2 Full 307.69M DISK 00:01:10 18-JUL-19
BP Key: 2 Status: AVAILABLE Compressed: NO Tag: TAG20190718T093005
Piece Name: /u01/app/rmanbak/db_TEST_20190718_02u6uu0u_1
List of Datafiles in backup set 2
File LV Type Ckp SCN Ckp Time Name
---- -- ---- ---------- --------- ----
1 Full 4596985 18-JUL-19 /u01/app/oracle/oradata/test/system01.dbf
8 Full 4596985 18-JUL-19 /u01/app/oracle/oradata/test/UNDO2.DBF BS Key Type LV Size Device Type Elapsed Time Completion Time
------- ---- -- ---------- ----------- ------------ ---------------
3 Full 1.47M DISK 00:00:00 18-JUL-19
BP Key: 3 Status: AVAILABLE Compressed: NO Tag: TAG20190718T093005
Piece Name: /u01/app/rmanbak/db_TEST_20190718_03u6uu3b_1
List of Datafiles in backup set 3
File LV Type Ckp SCN Ckp Time Name
---- -- ---- ---------- --------- ----
6 Full 4597020 18-JUL-19 /u01/app/oracle/oradata/test/tbs_1.dbf
。。。。。。。。。。。。。 List of Archived Logs in backup set 11
Thrd Seq Low SCN Low Time Next SCN Next Time
---- ------- ---------- --------- ---------- ---------
1 24 4597222 18-JUL-19 4597382 18-JUL-19
1 25 4597382 18-JUL-19 4597393 18-JUL-19

实验一  验证最小可指定SCN号

  注意我们指定的SCN为4597019,比上述数据文件6的scn457020还少1,报错为找不到文件6的备份。

  个人理解,在restore database时,rman只能找到scn为457020的文件6,并没有比其SCN小的数据文件备份,所以报错,而其他几个数据文件在备份时,SCN号小于4597019,可以在recover database进行增量恢复。说白了就是文件6最小的SCN是从457020开始。

  注:RMAN-06023 错也有可能是其他原因导致,此处实验只是为证明恢复时指定SCN问题!!!!

 [oracle@redhat3 ~]$ rman target /
Recovery Manager: Release 11.2.0.4.0 - Production on Thu Jul 18 10:26:56 2019
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
connected to target database: TEST (DBID=2274480208, not open)
RMAN> run{
2> set until scn 4597019;
3> restore database;
4> recover database;
5> }
executing command: SET until clause
Starting restore at 18-JUL-19
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=5 device type=DISK
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of restore command at 07/18/2019 10:26:59
RMAN-06026: some targets not found - aborting restore
RMAN-06023: no backup or copy of datafile 6 found to restore

  下面指定SCN 4597020恢复成功。

 RMAN> run{
2> set until scn 4597020;
3> restore database;
4> recover database;
5> }
executing command: SET until clause
Starting restore at 18-JUL-19
using channel ORA_DISK_1
channel ORA_DISK_1: starting datafile backup set restore
。。。。。。。。。。
channel ORA_DISK_1: restore complete, elapsed time: 00:00:03
Finished restore at 18-JUL-19
Starting recover at 18-JUL-19
using channel ORA_DISK_1
starting media recovery
。。。。。。。
Finished recover at 18-JUL-19

实验二 incarnation增长

  在SCN区间457020-4597382中,选一个进行不完全恢复,然后resetlogs,查看incarnation会+1。指定4597300进行恢复。

  可以发现在resetlogs后,执行list incarnation后,确认增加1条,且Reset SCN 4597301,比指定的4597300大1。数据库开启一个新的生命周期,在list incarnation命令中第3条记录的status 字段为CURRENT。

 RMAN> run{
2> set until scn 4597300;
3> restore database;
4> recover database;
5> }
executing command: SET until clause
Starting restore at 18-JUL-19
using channel ORA_DISK_1
。。。。。。。。。。。。。。。。
channel ORA_DISK_1: restored backup piece 1
channel ORA_DISK_1: restore complete, elapsed time: 00:00:03
Finished restore at 18-JUL-19 Starting recover at 18-JUL-19
using channel ORA_DISK_1
starting media recovery
。。。。。。。。。。。。
media recovery complete, elapsed time: 00:00:02
Finished recover at 18-JUL-19 RMAN> alter database open resetlogs;
database opened RMAN> list incarnation;
List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time
------- ------- -------- ---------------- --- ---------- ----------
1 1 TEST 2274480208 PARENT 4483656 11-JUL-19
2 2 TEST 2274480208 PARENT 4504768 11-JUL-19
3 3 TEST 2274480208 CURRENT 4597301 18-JUL-19

实验三 incarnation reset

  在实验二中,我们看到incarnation已经+1,如果在此时,需要重新恢复库至4597300之前的SCN号,将会出现什么情况?

  清理之前恢复的数据文件,日志文件(不要清理控制文件)

  如下所示,直接进行恢复,提示RMAN-20208,其实提示的也很清楚,就是告诉我们,控制文件里面已经记录过比这个SCN大的resetlogs,需要恢复的SCN不在当前数据库生命周期中。如需恢复,则需要把SCN重置到自己的生命周期中。

 [oracle@redhat3 ~]$ rman target /
Recovery Manager: Release 11.2.0.4.0 - Production on Thu Jul 18 11:17:23 2019
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
connected to target database: TEST (DBID=2274480208, not open)
RMAN> list incarnation;
using target database control file instead of recovery catalog List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time
------- ------- -------- ---------------- --- ---------- ----------
1 1 TEST 2274480208 PARENT 4483656 11-JUL-19
2 2 TEST 2274480208 PARENT 4504768 11-JUL-19
3 3 TEST 2274480208 CURRENT 4597301 18-JUL-19 RMAN> run{
2> set until scn 4597280;
3> restore database;
4> recover database;
5> }
executing command: SET until clause
Starting restore at 18-JUL-19
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of restore command at 07/18/2019 11:17:56
RMAN-20208: UNTIL CHANGE is before RESETLOGS change

  通过reset 命令可以重置数据库的生命周期。在重置后,可以看到第2号记录的STATUS字段调整为CURRENT。这时再进行恢复则正常。

 [oracle@redhat3 ~]$ rman target /
Recovery Manager: Release 11.2.0.4.0 - Production on Thu Jul 18 11:23:55 2019
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
connected to target database: TEST (DBID=2274480208, not open)
RMAN> list incarnation; using target database control file instead of recovery catalog
List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time
------- ------- -------- ---------------- --- ---------- ----------
1 1 TEST 2274480208 PARENT 4483656 11-JUL-19
2 2 TEST 2274480208 PARENT 4504768 11-JUL-19
3 3 TEST 2274480208 CURRENT 4597301 18-JUL-19 RMAN> reset database to incarnation 2; database reset to incarnation 2 RMAN> list incarnation; List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time
------- ------- -------- ---------------- --- ---------- ----------
1 1 TEST 2274480208 PARENT 4483656 11-JUL-19
2 2 TEST 2274480208 CURRENT 4504768 11-JUL-19
3 3 TEST 2274480208 ORPHAN 4597301 18-JUL-19 RMAN> run{
2> set until scn 4597280;
3> restore database;
4> recover database;
5> }
executing command: SET until clause
Starting restore at 18-JUL-19
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=5 device type=DISK
channel ORA_DISK_1: starting datafile backup set restore
。。。。。。。。。。。

总结

  通过上述的实验,我们可得出以下结论:

  1、rman恢复如指定SCN,则需要通过查看备份中数据文件的最大SCN号最为起点。

  2、在resetlogs后,如要恢复之前的SCN,则需要进行reset前身。(如果控制文件是重新恢复的,则不需要)

  3、实践是检验真理的唯一标准,作为DBA,多多动手实验才是王道。

 

在rman恢复中incarnation的概念的更多相关文章

  1. 记录一则RMAN恢复到历史备份(多个incarnation)

    环境: OEL 5.7 + Oracle 11.2.0.4 1.直接restore到想要恢复的时间点报错: RMAN> sql "alter session set nls_date_ ...

  2. Oracle Rman恢复

    (转自:http://blog.chinaunix.net/uid-14779297-id-1988309.html) RMAN的基本概念 Target Database:就是需要RMAN对其进行备份 ...

  3. Oracle DB 使用RMAN恢复目录

    • 对恢复目录和RMAN 资料档案库控制文件的使用进行比较• 创建和配置恢复目录• 在恢复目录中注册数据库• 同步恢复目录• 使用RMAN 存储脚本• 备份恢复目录• 创建虚拟专用目录 RMAN 资料 ...

  4. rman恢复方案和oracle异机恢复

    这篇文章主要介绍了rman恢复方案和oracle异机恢复,需要的朋友可以参考下 注:①恢复的前提是已经做好备份②完全恢复数据库是数据库遇到故障,在恢复时候没有丢失任何已经提交事物数据的恢复不完全恢复数 ...

  5. Oracle - RMAN备份 之 incarnation的实验和小结

    对于RMAN恢复我一直都不是很明白,因为,老是搞不清楚不完全恢复该怎么进行,今天,通过这个实验即是对不完全恢复的实践,也是希望搞清楚incarnation到底是怎么工作的.很可惜,本人对Oracle的 ...

  6. 12c RAC 用Rman 恢复到异机单实例

    准备工作 原服务器软件部署:Redhat 6.6 + Oracle 12.2.0.1 rac Oracle12c单实例安装 1.创建恢复服务器,设置大于原库数据大小的磁盘容量.设置相同的服务器主机名参 ...

  7. RAC+asm通过rman恢复到单实例+asm

    1.恢复参数文件,并修改参数文件 参数文件指名几个最简单的就行,我的参数文件如下: 2.恢复控制文件,并启动数据库到mount 如果是把备份集从别的服务器拷贝到本地恢复的服务器的目录,使用下面的语句指 ...

  8. oracle rman恢复数据库 方式恢复到异地数据库

    目的:从某个环境中,获取相关文件,放到异地机器使用rman 恢复.   情况说明:XX系统使用的是oracle数据库,现已从服务器拉下来相关文件,依靠这些文件来早本地的测试机上恢复数据库,方便进行数据 ...

  9. RMAN恢复目录

    是否使用RMAN恢复目录(Recovery Catalog 你可能从其他人或书上听过RMAN恢复目录(也有可能是其他名字,RMAN Recovery Catalog的翻译较多较杂,以下简称恢复目录), ...

随机推荐

  1. 简单易用的MongoDB

    从我第一次听到Nosql这个概念到如今已经走过4个年头了,但仍然没有具体的去做过相应的实践.最近获得一段学习休息时间,购买了Nosql技术实践一书,正在慢慢的学习.在主流观点中,Nosql大体分为4类 ...

  2. layui弹出框打开第二次select内容无法显示问题

    今天, 在使用layui弹出框的时候, 第一次进入select内容加载是正常的, 将弹出框关闭再次进入后select下拉框内容为空, 经排查是因为每次弹出窗口z-index都会改变, 弹出框的z-in ...

  3. Win8Metro(C#)数字图像处理--2.10图像中值滤波

    原文:Win8Metro(C#)数字图像处理--2.10图像中值滤波  [函数名称] 图像中值滤波函数MedianFilterProcess(WriteableBitmap src) [函数代码] ...

  4. Android零基础入门第79节:Intent 属性详解(上)

    Android应用将会根据Intent来启动指定组件,至于到底启动哪个组件,则取决于Intent的各属性.本期将详细介绍Intent的各属性值,以及 Android如何根据不同属性值来启动相应的组件. ...

  5. MySQL5.7.19版本压缩包安装方式的一些坑

    ySQL社区版下载地址:https://dev.mysql.com/downloads/mysql/,在这里也可以选择之前的版本下载. MySQL进入5.7.7版本以后,压缩包安装需要注意一些地方: ...

  6. 前端开发在手机UC浏览器上遇到的坑

    1.user-scalable问题 写手机页面都会加一个meta标签 <meta content="width=device-width, initial-scale=1.0, max ...

  7. STL函数static void (* set_malloc_handler(void (*f)()))()与函数指针解析

    在C++ STL的SGI实现版本中,一级空间配置器class __malloc_alloc_template中有一个静态函数的实现如下: static void (*set_malloc_handle ...

  8. vue-cli脚手架 ,过滤器,生命周期钩子函数

    一.安装vue-cli脚手架 1.淘宝镜像下载 用淘宝的国内服务器来向国外的服务器请求,我们向淘宝请求,而不是由我们直接向国外的服务器请求,会大大提升请求速度,使用时,将所有的npm命令换成cnpm即 ...

  9. 请你讲一讲JavaScript有哪些数据类型, 数据类型判断有哪些方法?

    js的8种数据类型 JavaScript中有8种数据类型, 包括基本数据类型(number, string, boolean, null, undefined, symbol, bigint)和引用数 ...

  10. 多进程界面开发-Qt试玩儿

    目录 一.概述 二.效果展示 三.使用方法 1.启动外部进程 2.创建Qt窗口 3.加入到主进程布局 四.嵌入NotePad 五.调用Ping命令 六.嵌入其他QWidget窗体 七.相关文章 一.概 ...