RMAN 数据库克隆文件位置转换方法

      在使用RMAN克隆数据库时,如果辅助数据库(新数据库)使用了与目标数据库(原数据库)使用了不同的路径,那么就存在位置转换的问题。在Oracle中,控制文件用于定位数据文件以及联机重做日志文件,如果没有正确的转换,控制文件压根就找不到相应的数据文件,日志文件。对此Oralce为我们提供了三种文件位置的转换方法。本文即是对这三种转换方法的描述。

1、使用db_file_name_convert与log_file_name_convert参数

--我们可以在辅助数据库参数文件spfile/pfile中定义这两个参数用于Oracle来根据这个值进行自动转换文件位置
--该参数也可以用于配置dataguard是主数据库与standby数据库文件位置转换
--第一个字符串用于定义目标数据库文件位置,第二个字符串用于定义辅助数据库文件位置
--如下面的示例
*.db_file_name_convert =('/u01/database/sybo3','/u02/database/sybo5')
*.log_file_name_convert =('/u01/database/sybo3','/u02/database/sybo5')

--如果辅助数据库文件的位置有关的其他信息,如加载点都是相同的,可以直接使用下面的方式来定义参数
--target db path: /u01/database/sybo3
--auxiliary db path: /u01/database/sybo5
--做如下定义
*.db_file_name_convert =('sybo3','sybo5')
*.log_file_name_convert =('sybo3','sybo5')

--如果是下面的情形
--target db path:
  /u01/database/sybo3/oradata/system01.dbf
  /u01/database/sybo3/oradata/sysaux01.dbf
  /u02/database/sybo3/oradata/undotbs01.dbf
  /u02/database/sybo3/oradata/users01.dbf
  /u02/database/sybo3/oradata/example01.dbf

--auxiliary db path:
    /u01/database/sybo5/oradata/system01.dbf
  /u01/database/sybo5/oradata/sysaux01.dbf
  /u02/database/sybo5/oradata/undotbs01.dbf
  /u02/database/sybo5/oradata/users01.dbf
  /u02/database/sybo5/oradata/example01.dbf

--如前所述,由于加载点是相同的,依旧可以按上面的方式定义
*.db_file_name_convert =('sybo3','sybo5') 
*.log_file_name_convert =('sybo3','sybo5') 

--下面是克隆之后的情形,最好清除这个两个参数
[oracle@linux3 ~]$ rman target sys/oracle@sybo3 auxiliary sys/oracle@sybo5

RMAN> duplicate target database to sybo5;  --发布该命令后,Oracle会根据目标数据库自动创建辅助数据库日志文件以及临时表空间数据文件

SQL> select name,dbid,open_mode from v$database;

NAME            DBID OPEN_MODE
--------- ---------- --------------------
SYBO5     2292457546 READ WRITE

SQL> show parameter name_conve

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_file_name_convert                 string      sybo3, sybo5
log_file_name_convert                string      sybo3, sybo5
SQL> alter system reset db_file_name_convert;

System altered.

SQL> alter system reset log_file_name_convert;

System altered.

2、使用RMAN set newname子句

RMAN 为我们提供了set newname 子句用于指定辅助数据库数据文件以及临时表空间数据文件的位置。
该命令也可以用于特定表空间或数据文件因加载点失败将数据文件恢复到非故障加载点。
如下:
  set newname for datafile m to '<new_dir>/file_name'
  set newname for tempfile n to '<new_dir>/file_name'
  
如我们可以使用下面的命令来克隆数据库

RMAN> run
{
set newname for datafile 1  to '/u01/database/sybo5/oradata/system01.dbf';     -->为数据文件指定新路径              
set newname for datafile 2  to '/u01/database/sybo5/oradata/sysaux01.dbf';                        
set newname for datafile 3  to '/u01/database/sybo5/oradata/undotbs01.dbf';                       
set newname for datafile 4  to '/u01/database/sybo5/oradata/users01.dbf';                         
set newname for datafile 5  to '/u01/database/sybo5/oradata/example01.dbf';                       
set newname for tempfile 1  to '/u01/database/sybo5/oradata/temp01.dbf';       -->为日志文件指定新路径
duplicate target database to sybo5                                             -->duplicate 命令用于克隆数据库
logfile
group 1 ('/u01/database/sybo5/redo/redo01a.log','/u01/database/sybo5/redo/redo01b.log') size 10m, -->可自行指定日志组及成员数,size
group 2 ('/u01/database/sybo5/redo/redo02a.log','/u01/database/sybo5/redo/redo02b.log') size 10m, -->如未指定logfile部分则其组数与
group 3 ('/u01/database/sybo5/redo/redo03a.log','/u01/database/sybo5/redo/redo03b.log') size 10m; -->成员数,size等同于与目标数据库
switch datafile all;                                                   -->用于将上述新路径更新到控制文件,此句可省略(会自动更新)                                 
}

3、使用configure auxname命令

configure auxname是在Oracle 11g开始提供的新命令,该配置命令会将其值存储在目标数据库的控制文件中
用法如下:
  configure auxname for datafile n to '<new_dir>/file_name';
  configure auxname for datafile n clear;

--Author : Robinson
--Blog   : http://blog.csdn.net/robinson_0612

如下面是设置之后的结果:  
RMAN> show auxname;

RMAN configuration parameters for database with db_unique_name SYBO3 are:
CONFIGURE AUXNAME FOR DATAFILE '/u01/database/sybo3/oradata/system01.dbf' TO '/u01/database/sybo5/oradata/system01.dbf';
CONFIGURE AUXNAME FOR DATAFILE '/u01/database/sybo3/oradata/sysaux01.dbf' TO '/u01/database/sybo5/oradata/sysaux01.dbf';
CONFIGURE AUXNAME FOR DATAFILE '/u01/database/sybo3/oradata/undotbs01.dbf' TO '/u01/database/sybo5/oradata/undotbs01.dbf';
CONFIGURE AUXNAME FOR DATAFILE '/u01/database/sybo3/oradata/users01.dbf' TO '/u01/database/sybo5/oradata/users01.dbf';
CONFIGURE AUXNAME FOR DATAFILE '/u01/database/sybo3/oradata/example01.dbf' TO '/u01/database/sybo5/oradata/example01.dbf'; 

RMAN>run 
{
set until time = "to_date('20130725 10:09:53','yyyymmdd hh24:mi:ss')";  -->可以指定time,scn,sequence 
set newname for tempfile 1 TO '/u01/database/sybo5/oradata/temp01.dbf'; -->注意,configure auxname不支持tempfile,此处需要使用set newname
duplicate target database to clone_db pfile=/u01/oracle/db_1/dbs/initsybo5.ora
logfile
'/u01/database/sybo5/redo/redo01a.log' SIZE 5M, 
'/u01/database/sybo5/redo/redo02a.log' SIZE 5M, 
'/u01/database/sybo5/redo/redo03a.log' SIZE 5M;  
} 

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IT 指南者专栏

【SSH框架】之Hibernate系列(一)

微信公众号:compassblog 欢迎关注、转发,互相学习,共同进步! 有任何问题,请后台留言联系! 1、Hibernate框架概述 (1)、什么是Hiber...

28880
来自专栏张戈的专栏

常用MySQL语句搜集整理

折腾 WordPress 多少要接触到 MySQL 的一些操作,比如,玛思阁之前重装 postview 插件后发现所有的 view 数据都被清空了!只好到 ph...

40950
来自专栏程序小工

windows7使用Sphinx+PHP+MySQL详细介绍

由于业务需要,需要做类似淘宝商城商品检索的功能,对于数据量很大的情况,MySQL 查询的效率损耗很大,需要使用专门的索引引擎进行搜索查询,实现功能,对于和 PH...

56410
来自专栏沃趣科技

ASM 翻译系列第十五弹:ASM Internal ASM File Directory

原作者:Bane Radulovic 译者: 郭旭瑞 审核: 魏兴华 DBGeeK社群联合出品 ASM File Directory 本篇主要介绍A...

38440
来自专栏数据和云

【循序渐进Oracle】Oracle的逻辑备份与恢复

编辑手记:针对最近发生的炉石及GitLab事件,我们不得不再次强调备份的重要性。DBA的四大守则,第一条就是备份重于一切。年初做好备份,愿你的系统17无恙。 本...

48880
来自专栏python3

django操作非ORM创建的表

工作中会遇见很多二次开发的时候,表都是已经创建好的,用django的ORM进行二次开发,怎么操作数据库中的表呢?

20420
来自专栏抠抠空间

MySQL 之 视图、触发器、存储过程、函数、事物与数据库锁

浏览目录: 1.视图 2.触发器 3.存储过程 4.函数 5.事物 6.数据库锁 7.数据库备份 1.视图 视图:是一个虚拟表,其内容由查询定义。同真实的表...

45570
来自专栏大数据和云计算技术

MonetDB学习笔记

这个文章是我2013年6月写在博客里面的,翻出来挺有意思,MonetDB有很多技术值得学习。 1 架构: 三层软件架构: SQL front-end:前端SQL...

647110
来自专栏Porschev[钟慰]的专栏

Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例

前言   前面一有写到一篇Node.js+Express构建网站简单示例https://cloud.tencent.com/developer/article/...

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

一条关于swap争用的报警邮件分析(一)(r7笔记第28天)

最近这些天有一台服务器总是会收到剩余swap过低的告警。 邮件内容大体如下: ############ ZABBIX-监控系统: --------------...

38940

扫码关注云+社区

领取腾讯云代金券