使用RMAN DUPLICATE 命令可以在保留目标数据库的基础上依靠目标数据库(Target Database)的备份创建 一个副本数据库(Duplicate Database)

辅助实例是创建副本数据库的重要一步,一般而言会有下列几个步骤

一、创建辅助实例的密码文件

orapwd file=$\database\PWDjssdup.ora password=oracle entries=30

二、连接实例

注意,windows环境需要先通过ORADIM命令创建一个新的OracleService, Linux环境可以跳过这一步,其它操作还是要继续。

oradim -new -sid jssdup

然后配置监听,修改tnsname.ora。总之能够连接上辅助实例就可以了。

三、创建辅助实例的初始化参数文件

1. 手工创建相应目录

cluster mysql 副本 数据库建立副本_初始化

2. 创建本地初始化参数文件并修改参数

在源数据库生成pfile

SQL> create pfile='D:\learnoracle\pfile.ora' from spfile;

用记事打开并更改相应的参数。并添加以下两参数:

db_file_name_convert='oradata\jssweb','oradata\jssdup'
log_file_name_convert='oradata\jssweb','oradata\jssdup'

 3. 在辅助数据库中创建初始化参数文件-在primary数据库生成的pfile基础上修改

SQL> create spfile from pfile='D:\learnoracle\pfile.ora';

 4. 启动辅助实例

接着上一步创建完spfile之后:

SQL> startup force nomount;

 

5. 确保源数据库处于mount或open的状态

 

6. 确认拥有必备的备份

 

7. 分配辅助通道

 首先运行rman连接到目标数据库和辅助实例

set oracle_sid=orcl

rman target/ auxiliary sys/oracle@jssdup

这里可能会出现如下的错误信息:

Recovery Manager: Release 11.1.0.6.0 - Production on Wed Nov 7 01:45:35 2007
Copyright (c) 1982, 2007, Oracle. All rights reserved.

connected to target database: ORA11G (DBID=4026820313)
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-00554: initialization of internal recovery manager package failed
RMAN-04006: error from auxiliary database: ORA-12528: TNS:listener: all appropriate instances are blocking new connections

造成这个问题的原因是,实例虽然启动,但是没有注册到监听。实例是通过PMON进程注册到监听上的,而PMON进程需要在MOUNT状态下才会启动。因此造成了上面的错误。

Oracle给出了两种解决方案,一种方法是对AUXILIARY数据库直接使用/,对TARGET数据库通过网络访问。

a. rman target sys/oracle@orcl auxiliary /

b. 为AUXILIARY数据库设置静态监听

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = jssdup)
(ORACLE_HOME = /data/oracle/product/11.1)
)
)

 

启动正常后分配通道。如下例:

RMAN>RUN

{

ALLOCATE AUXILIARY CHANNEL aux1 DEVICE TYPE DISK;

ALLOCATE AUXILIARY CHANNEL aux2 DEVICE TYPE DISK;

ALLOCATE AUXILIARY CHANNEL aux3 DEVICE TYPE DISK;

DUPLICATE TARGET DATABASE TO jssdup;

release channel aux1;

release channel aux2;

release channel aux3;

}

 

执行到这一步辅助实例就已创建完成了:)

 

删除辅助数据库

-只须通过dbca即可