不同配置决定不同的复制的流程。 一、远程站点相同路径结构的复制
' |& i! G# {3 H Duplicating a Database on a Remote Host with the Same Directory Structure
$ N. w, m8 M9 ]' T 对于这种选择而言,操作实在太过简单,你甚至不需要修改初始化参数文件或者重命名复制的数据文件(可惜,做测试的话这却不能做为我们的首选,一般测试都只有一台机器,难道让我再虚拟个操作系统?)如果是多台机器的话,这种操作非常省事,步骤也很少:+ N7 D/ A! y, X% H
1、创建辅助实例。' g0 ~9 q" O8 ]" W# g
2、Rman连接并运行duplicate命令,结束。3 w% W7 K6 p2 ~, }/ x6 \
确实太简单的是吧,好吧那我来给你找点麻烦,注意第2步,其执行是有几个先决条件的。或者说伟大的oracle大人又一次下放了它高贵的权力,而给你来做出选择,如下:
, D, B% g% t+ b" ?) j 如果没有配置自动分配通道的话,表忘记至少手工指定1条辅助通道。1 q6 Q; R8 B9 _ ]7 v6 M! I; }0 L* M
不要忘记指定NOFILENAMECHECK参数。
' D: X6 B, C0 v/ ?( U, E, T, N$ N 就像前面说的,如果辅助实例并非服务器端初始化参数文件启动,表忘记指定PFILE参数。更加表忘记该文件必须在运行RMAN的客户端上。
: A- W, q4 j* g. K7 M/ P1 X 例如,假设你配置了自动分配通道,并且决定使用pfile启动辅助实例,那么在RMAN连接到目标库和辅助实例之后,只需要执行下列:
& ^7 [) {( E1 H0 D$ p
0 F* u5 y/ v8 W& ~9 @5 ]. C- g+ N5 [' L2 U. F6 c: I+ Y4 D
DUPLICATE TARGET DATABASE TO dupdb PFILE = F:\oracle\product\10.2.0\admin\jssdup\pfile\init.ora NOFILENAMECHECK;
0 Y$ f* z' X" B 最后,RMAN会自动以RESETLOGS方式打开数据库并重建REDO LOGS.竣工。
5 o. D$ A: m- E0 r1 i9 a/ g" C 二、远程站点不同路径结构的复制4 Y: v/ C$ m" u
Duplicating a Database on a Remote Host with a Different Directory Structure
6 C; V. `3 p+ e) Z, b r5 y V 如果副本数据库创建在远程站点,并且目录结构也不一致,那么你必须修改几个初始化参数值以便副本数据库的数据文件能够在新的目录结构存取。这种类型的复制又可以细分成几个小类:- H3 M: W6 t w! M! a$ ]
1、在初始化参数中重命名复制文件和日志文件,复制步骤如下:9 D; a/ d0 y9 Q4 @ i% E
a) 首先还是创建辅助实例。注意初始化参数的配置,按下列的方式进行一些调整。/ W9 f4 J9 \% {8 Y1 p9 `
? 浏览初始化参数中以_DEST结尾的参数以及包含路径的参数,确认这些路径对即将创建的副本数据库有效。
7 \" S! o: K1 O. K1 }" J ? 设置DB_FILE_NAME_CONVERT参数,让其自动转换数据文件路径。8 Z1 |7 [* T; _, e* ~0 `
? 设置LOG_FILE_NAME_CONVERT参数,让其自动转换日志文件路径。
) V; C0 _) w7 s% L 所谓道有千条我取其一,除了上述方式之外呢,还有很多其它方法来指定文件存放路径,比如CONFIGURE AUXNAME或SET NEWNAME命令等等。不过此处是在写初始化参数中重命名类型的复制,就不多占篇章了,后面有章节专门讲解。感兴趣的朋友不妨keep你的好奇心,往下看:)+ g) {! `1 Y% ~( z' F1 u
b) RMAN连接并执行duplicate命令,结束。7 E) E& z$ t+ r$ h$ `
在这里同样需要注意辅助通道的分配和pfile的加载(如果使用pfile的话)。0 W; J2 t2 T; w. V" r
例如,我们使用自动分配通道,并且辅助实例使用服务器端初始化参数文件,这下dulicate命令更简单了:) a) J; K/ z: T3 W) b/ c
DUPLICATE TARGET DATABASE TO dupdb;: _1 x+ [4 F( Q0 u
这种方式主要的工作都在创建辅助实例上。
# _5 g( \% v5 I( i 2、在Duplicate命令中重命名数据、日志文件,复制步骤如下:/ ]2 C9 e$ g) `& u+ I3 }
a. 创建辅助实例。
& ^1 U( B0 c# o5 ]: ~ u b. RMAN连接运行Duplicate命令,注意此处需要加些参数如下:/ z+ {3 B/ Z2 R3 b6 z
? 通道,还是通道!如果没有自动分配通道,则至少要手工指定一条辅助通道。3 a+ U5 I! ^2 g. w% g7 y' s$ ?
? 通过LOGFILE子句指定副本数据库redo logs文件地址大小等。
' B. y$ l6 ]( @; Q' l$ T+ K y1 p3 Z ? 通过DB_FILE_NAME_CONVERT转换原数据文件路径到新路径。' ^. Z0 }, E/ i; f. ]8 c, @" @
? pfile,又见pfile.如果使用了pfile的话,表忘记指定pfile参数。 |