How To Restore Rman Backups On A Different Node When The Directory Structures Are Different (Doc ID 419137.1)
How To Restore Rman Backups On A Different Node When The Directory Structures Are Different (Doc ID 419137.1)
APPLIES TO:
Oracle Database - Enterprise Edition - Version 10.1.0.2 and later
Information in this document applies to any platform.
***Checked for relevance on 20-July-2015***
GOAL
Restoring Rman backup on a different node with different backup directory structures and different database directory structures .
在具有不同备份目录结构和不同数据库目录结构的不同节点上还原Rman备份
++ The database has to be has to be restored from the Rman backup on NODE 2. 该数据库必须是已经被从RMAN备份中恢复节点2
++ The directory structures for the backups and the database files are different on NODE 2. 用于备份的目录结构和数据库文件在节点2不同
++ The Rman backups have to put in new directory structure on NODE 2 unlike as they were on NODE 1. Rman备份必须在NODE 2上放入新的目录结构,这与在NODE 1上不同。
++ Also the database has to be restored to a different directory structure on NODE 2. 同样,数据库也必须还原到NODE 2上的其他目录结构
SOLUTION
ASSUMPTIONS 假设
-----------------------
++ The database files on NODE 1 are in '/<node1 path>/data' NODE 1上的数据库文件位于'/<node1 path>/data'
++ The backups on NODE 2 will be in location '/<node2 path>/backup' NODE 2上的备份将位于'/<node2 path>/backup'
++ The database files on NODE 2 will be restored to '/<node2 path>/data' NODE 2上的数据库文件将还原到'/<node2 path>/data'
Steps to acheive the goal: 实现目标的步骤
1) Connect to the target database using rman and backup the database ---> ON NODE 1
- $ rman target /
- Recovery Manager: Release 10.2.0.1.0 - Production on Tue Feb 13 00:29:33 2007
- Copyright (c) 1982, 2005, Oracle. All rights reserved.
- connected to target database: <DB_NAME> (DBID=3932056136)
- RMAN> backup database plus archivelog;
- Starting backup at 13-FEB-07
- current log archived
- using channel ORA_DISK_1
- channel ORA_DISK_1: starting archive log backupset
- channel ORA_DISK_1: specifying archive log(s) in backup set
- input archive log thread=1 sequence=143 recid=109 stamp=614392105
- channel ORA_DISK_1: starting piece 1 at 13-FEB-07
- channel ORA_DISK_1: finished piece 1 at 13-FEB-07
- piece handle=/<node1 path>/backup/o1_mf_annnn_TAG20070213T002825_2x21kbds
- _.bkp tag=TAG20070213T002825 comment=NONE
- channel ORA_DISK_1: backup set complete, elapsed time: 00:00:02
- Finished backup at 13-FEB-07
- Starting backup at 13-FEB-07
- using channel ORA_DISK_1
- channel ORA_DISK_1: starting full datafile backupset
- channel ORA_DISK_1: specifying datafile(s) in backupset
- input datafile fno=00003 name=/<node1 path>/data/sysaux01.dbf
- input datafile fno=00001 name=/<node1 path>/data/system01.dbf
- input datafile fno=00002 name=/<node1 path>/data/undotbs01.dbf
- input datafile fno=00004 name=/<node1 path>/data/users01.dbf
- input datafile fno=00005 name=/<node1 path>/data/1.dbf
- input datafile fno=00006 name=/<node1 path>/data/sysaux02.dbf
- input datafile fno=00007 name=/<node1 path>/data/undotbs02.dbf
- channel ORA_DISK_1: starting piece 1 at 13-FEB-07
- channel ORA_DISK_1: finished piece 1 at 13-FEB-07
- piece handle=/<node1 path>/backup/o1_mf_nnndf_TAG20070213T002827_2x21kd12
- _.bkp tag=TAG20070213T002827 comment=NONE
- channel ORA_DISK_1: backup set complete, elapsed time: 00:00:55
- Finished backup at 13-FEB-07
- Starting backup at 13-FEB-07
- current log archived
- using channel ORA_DISK_1
- channel ORA_DISK_1: starting archive log backupset
- channel ORA_DISK_1: specifying archive log(s) in backup set
- input archive log thread=1 sequence=144 recid=110 stamp=614392165
- channel ORA_DISK_1: starting piece 1 at 13-FEB-07
- channel ORA_DISK_1: finished piece 1 at 13-FEB-07
- piece handle=/<node1 path>/backup/o1_mf_annnn_TAG20070213T002925_2x21m6ty
- _.bkp tag=TAG20070213T002925 comment=NONE
- channel ORA_DISK_1: backup set complete, elapsed time: 00:00:02
- Finished backup at 13-FEB-07
- Starting Control File and SPFILE Autobackup at 13-FEB-07
- piece handle=/<oracle_home>/dbs/c-3932056136-20070213-02 comment=NONE
- Finished Control File and SPFILE Autobackup at 13-FEB-07
- RMAN> exit
2) Move the following files to the NODE 2: 将以下文件移至NODE 2
- + The database backup pieces to location '/<node2 path>/backup'
- + Controlfile backup piece to the location '/<node2 path/backup'
- + The parameter file i.e init.ora file to the default location i.e $ORACLE_HOME/dbs
3) Edit the PFILE on NODE 2 to change the environment specific parameters like .
- user_dump_dest =
- background_dump_dest =
- control_files =
4) Once the PFILE is suitably modified invoke Rman on the NODE 2 after setting the Oracle environment variables and start the database in nomount mode:
- $ export ORACLE_HOME=/<oracle_home>
- $ export ORACLE_SID=<oracle_sid>
- $ export PATH=$ORACLE_HOME/bin:$PATH
- $ rman target /
- Recovery Manager: Release 10.2.0.1.0 - Production on Tue Feb 13 00:36:55 2007
- Copyright (c) 1982, 2005, Oracle. All rights reserved.
- connected to target database (not started)
- RMAN> startup nomount
- Oracle instance started
- Total System Global Area 205520896 bytes
- Fixed Size 1218508 bytes
- Variable Size 75499572 bytes
- Database Buffers 121634816 bytes
- Redo Buffers 7168000 bytes
5) Restore the controlfile from the backup piece.
- RMAN> restore controlfile from '/<node2 path/backup/c-3932056136-20070213-02';
- Starting restore at 13-FEB-07
- using target database control file instead of recovery catalog
- allocated channel: ORA_DISK_1
- channel ORA_DISK_1: sid=155 devtype=DISK
- channel ORA_DISK_1: restoring control file
- channel ORA_DISK_1: restore complete,
- elapsed time: 00:00:02
- output filename=/<node2 path/data/control01.ctl
- Finished restore at 13-FEB-07
6) Mount the database
- RMAN > alter database mount
7) Now catalog the backup pieces that were shipped from NODE 1
- RMAN> catalog backuppiece '/<node2 path/backup/o1_mf_annnn_TAG20070213T002925_2x21m6ty_.bkp';
- RMAN> catalog backuppiece '/<node2 path/backup/o1_mf_annnn_TAG20070213T002825_2x21kbds_.bkp';
- RMAN> catalog backuppiece '/<node2 path/backup/o1_mf_nnndf_TAG20070213T002827_2x21kd12_.bkp';
8) Get to know the last sequence available in the archivelog backup using the following command.This will help us in recovering the database till that archivelog.
使用以下命令了解archivelog备份中的最后一个可用sequence,这将有助于我们恢复数据库直到该archivelog
- RMAN > list backup of archivelog all;
- Let us assume the last sequence of last archivelog in the backup is 50.
9) Rename the Redolog files,so that they can be created in new locations when opened the database is opened in resetlogs
重命名Redolog,以便在resetlogs打开数据库时可以在新位置创建它们
- SQL> alter database rename file '/<node1 path>/data/redo01.log' to '/<node2 path>/data/redo01.log';
- ......
- ......
- ......
10) Now restore the datafiles to new locations and recover. Since we are recovering the database here till the archivelog sequence 50 the sequence number in the SET UNTIL SEQUENCE clause
现在将数据文件restore到新位置并recover。由于我们在此处recover数据库,直到存档日志序列50为止,SET UNTIL SEQUENCE 子句中的序列号
- RMAN> run
- {
- set until sequence 51;
- set newname for datafile 1 to '/<node2 path>/data/sys01.dbf';
- set newname for datafile 2 to '/<node2 path>/data/undotbs01.dbf';
- set newname for datafile 3 to '/<node2 path>/data/sysaux01.dbf';
- set newname for datafile 4 to '/<node2 path>/data/users01.dbf';
- set newname for datafile 5 to '/<node2 path>/data/1.dbf';
- set newname for datafile 6 to '/<node2 path>/data/sysaux02.dbf';
- set newname for datafile 7 to '/<node2 path>/data/undotbs02.dbf';
- restore database;
- switch datafile all;
- recover database;
- alter database open resetlogs;
- }
如果我们要从磁带还原Rman备份,那么我们应该确保在还原过程中也保持与备份期间使用的介质管理器变量相同的方式。
The below article gives the information of various media manager Environment Variables.
下面的文章提供了各种媒体管理器环境变量的信息
NOTE.312737.1 RMAN and Specific Media Managers Environment Variables.
11) Confirm your tempfiles
Confirm the location of your tempfiles, recreate them at the new location if required:
确认tempfiles的位置,如果需要,请在新位置重新创建它们
- SQL> select * from v$tempfile;
- SQL> ALTER TABLESPACE TEMP ADD TEMPFILE 'new tempfile path filename' REUSE;
REFERENCES
NOTE:228257.1 - RMAN 'Duplicate Database' Feature in Oracle9i / 10G and 11G
NOTE:73974.1 - RMAN: Restoring an RMAN Backup to Another Node
How To Restore Rman Backups On A Different Node When The Directory Structures Are Different (Doc ID 419137.1)的更多相关文章
- How to restore and recover a database from an RMAN backup. (Doc ID 881395.1)
APPLIES TO: Oracle Database - Enterprise Edition - Version 10.1.0.2 to 11.2.0.2 [Release 10.1 to 11. ...
- 如何将RAC数据库的 RMAN Disk 备份 Restore 到另一个节点上的单个实例 (Doc ID 415579.1)
HowTo Restore RMAN Disk backups of RAC Database to Single Instance On Another Node (Doc ID 415579.1) ...
- Checklist for an RMAN Restore (Doc ID 1554636.1)
Checklist for an RMAN Restore (Doc ID 1554636.1) APPLIES TO: Oracle Database - Enterprise Edition - ...
- RMAN RECOVER TABLE 功能是 Oracle Database 12c 的新增功能 (Doc ID 1521524.1)
RMAN RECOVER TABLE Feature New to Oracle Database 12c (Doc ID 1521524.1) APPLIES TO: Oracle Database ...
- Rman Enhancements(增强) In Oracle 11g. (Doc ID 1115423.1)
Rman Enhancements In Oracle 11g. (Doc ID 1115423.1) APPLIES TO: Oracle Database - Enterprise Edition ...
- ORA-4031 During Startup Nomount using RMAN without parameter file (PFILE) (Doc ID 1176443.1)
ORA-4031 During Startup Nomount using RMAN without parameter file (PFILE) (Doc ID 1176443.1) APPLIES ...
- 如何使用块更改跟踪文件估算RMAN增量备份大小 (Doc ID 1938079.1)
How to estimate RMAN incremental backup size using block change tracking file (Doc ID 1938079.1) APP ...
- RMAN DUPLICATE DATABASE with SET NEWNAME failed: RMAN-05501 RMAN-05517 (Doc ID 387093.1)
RMAN DUPLICATE DATABASE with SET NEWNAME failed: RMAN-05501 RMAN-05517 (Doc ID 387093.1) APPLIES TO: ...
- RMAN 'Duplicate From Active Database' Feature in Oracle11g (Doc ID 452868.1)
RMAN 'Duplicate From Active Database' Feature in Oracle11g (Doc ID 452868.1) APPLIES TO: Oracle Data ...
随机推荐
- Java连载59-局部内部类、匿名内部类
一.局部内部类 1.局部内部类等同于局部变量 2.局部内部类在访问局部变量的时候,局部变量必须使用final修饰. 3.举个例子: package com.bjpowernode.java_learn ...
- js的cookies及html5的localStorage、sessionStorage
1.首先,理解什么是cookies? cookies:存储在客户端,数据量小的,会过期的数据,以字符串形式存储 cookie操作代码示例: <script> window.onload = ...
- Docker安全扫描工具之docker-bench-security
简介 Docker Bench for Security检查关于在生产环境中部署Docker容器的几十个常见最佳实践.这些测试都是自动化的,其灵感来自CIS Docker基准1.2.0版. 这种安全扫 ...
- 2019 Vue开发指南:你都需要学点啥?
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者.原文出处:https://dzone.com/articles/vue-development-in-2019 ...
- C# base
using System; using System.Collections.Generic; using System.Text; namespace 继承 { class Program { st ...
- 在 Python 3.x 版本后,ConfigParser.py 已经更名为 configparser.py 所以出错!
在 Python 3.x 版本后,ConfigParser.py 已经更名为 configparser.py 所以出错!
- Java源码记录 - AbstractMap
路径java.util.AbstractMap ()构造方法 /** * 唯一的构造器.(一般由子类隐式调用) */ protexted AbstractMap(){ } size()返回当前map的 ...
- Cesium数据可视化-仓储调度系统可视化部分(附github源码)
Cesium数据可视化-仓储调度系统可视化部分 目的 仓储调度系统需要一个可视化展示物资运输实况的界面,需要配合GPS设备发送的位置信息,实时绘制物资运输情况和仓储仓库.因此,使用Cesium可视化该 ...
- leetcode题解:两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组中同样的元 ...
- hibernate-positional-parameter-does-not-exist-1-in-query
经过bug的排查,问题出在,scsj字段的赋值上; 通过字符串在数据库端生成即可: