标签:
Oracle数据库克隆,也叫着Oracle数据库复制,可以通过基于用户管理的方式来完成,也可以基于RMAN方式来实现。而且Oracle建议使用RMAN方式来实现,因为它简单易用,隐藏其复杂的逻辑,仅仅是执行一条duplicate命令就可以喝茶了。当然,前期的准备工作也是不可少滴,如创建相应的dump目录,准备参数文件,配置监听等等。本文描述了Oracle 11g下如何使用RMAN实现同机克隆数据库。
1、RMAN克隆的几种类型
a、利用RMAN备份克隆并访问目标数据库(也就是原数据库),也就是复制期间由Oracle net与目标数据库保持连接
b、利用RMAN备份克隆不访问目标数据库,比如网络不通阿,目标数据库不可用等等,总之是人为或故障使得与目标库失去连接
c、直接使用活动数据库(active)进行克隆,实时备份加克隆,够牛滴!
2、RMAN克隆做了什么?
RMAN克隆根据需要连接或不连接到目标数据库后,需要连接一个辅助实例。这个辅助实例也就是我们复制后的实例。
我们知道任何一个数据库至少有一个实例与之对应,如果是RAC环境则可以多个实例对应一个数据库。
因此,我们在克隆数据库之前先建一个nomount状态的辅助实例用于分配内存等等一系列的后台进程啦。
有了实例就好办啦,RMAN为这个辅助实例生成控制文件,基于这个实例上还原数据库,恢复数据库等等不拉不拉的N多操作。
那这个N多操作靠谁呢,那就是发布命令: duplicate target databaseto aux_db
那RMAN如何连接到辅助实例呢? 与连接target或catalog方式类似,connect auxiliary name/pwd@tnsstring
通常情况下,对于磁盘备份还原操作,RMAN会自动创建及分配相应的通道,辅助实例也不例外,当然是自动分配辅助通道
而在磁带介质就麻烦一点了,需要手工来指定其通道,并行度等等。
下面简要描述一下RMAN克隆不同阶段都作了什么吧,关于克隆数据库时数据文件位置转换请参考: RMAN 数据库克隆文件位置转换方法
a、RMAN确定备份的属性,位置等等,也就备份存在性,可用等等了。
b、RMAN为辅助实例分配通道及辅助通道的参数设置
c、RMAN还原数据文件到辅助实例(此时使用了目标数据库控制文件)
d、RMAN构建辅助实例的控制文件
e、根据需要还原归档日志并进行相应的介质恢复
f、重置辅助实例的dbid,并使用open resetlog方式打开数据库,此时会创建相应的联机重做日志文件
3、RMAN克隆大致步骤
a、备份目标数据库(根据需要克隆类型而定,异机的话ftp一下,此步也可以置于步骤e之后,f之前)
b、创建相应的dump文件夹
c、配置辅助实例参数文件
d、生成辅助实例密码文件
e、配置辅助实例监听
f、实施数据库克隆(辅助实例启动到nomount状态后)
h、验证结果
4、RMAN同机克隆亲密接触
标签:
原文地址:http://www.cnblogs.com/andy6/p/5894950.html