使用RMAN的DUPLICATE克隆Oracle10gR2 数据库

简介:

这里我已经有一个安装好的数据库,版本是:10g R2  主机名称:dg1.andylhz.com 实例名dg,另外一台数据库主机,安装oracle软件和第一台数据库的安装环境一样,但没有安装数据库。主机名称:dg2.andylhz.com,实例名,dgc

 

1、将dg1的系统参数文件,监听文件,密码文件,拷贝到dg2的相应位置。

编辑初始化参数文件initdg.ora 将文件中的dg全部替换成dgc 保存并重命名为:initdgc.ora

如下:

[oracle@dg2 dbs]$ more /u01/app/oracle/10g/dbs/initdgc.ora

dgc.__db_cache_size=67108864

dgc.__java_pool_size=4194304

dgc.__large_pool_size=4194304

dgc.__shared_pool_size=88080384

dgc.__streams_pool_size=0

*.audit_file_dest='/u01/app/oracle/admin/dgc/adump'

*.background_dump_dest='/u01/app/oracle/admin/dgc/bdump'

*.compatible='10.2.0.1.0'

*.control_files='/u01/app/oracle/oradata/dgc/control01.ctl','/u01/app/oracle/oradata/dgc/control02.ctl','/u01/app/oracle/oradata/dgc

/control03.ctl'

*.core_dump_dest='/u01/app/oracle/admin/dgc/cdump'

*.db_block_size=8192

*.db_domain=''

*.db_file_multiblock_read_count=16

*.db_name='dgc'

*.db_recovery_file_dest='/u01/app/oracle/flash_recovery_area'

*.db_recovery_file_dest_size=2147483648

*.dispatchers='(PROTOCOL=TCP) (SERVICE=dgXDB)'

*.job_queue_processes=10

*.log_archive_format='%t_%s_%r.dbf'

*.open_cursors=300

*.pga_aggregate_target=16777216

*.processes=150

*.remote_login_passwordfile='EXCLUSIVE'

*.sga_target=167772160

*.undo_management='AUTO'

*.undo_tablespace='UNDOTBS1'

*.user_dump_dest='/u01/app/oracle/admin/dgc/udump'

*.db_file_name_convert='/u01/app/oracle/oradata/dg','/u01/app/oracle/oradata/dgc'

*.log_file_name_convert='/u01/app/oracle/oradata/dg','/u01/app/oracle/oradata/dgc'   

#红色字体的参数需要设置好,否则在执行duplicate命令的时候报告辅助数据库和目标数据库的文件命冲突。

 

2、将密码文件重命名:mv orapwdg  orapwdgc

3、将监听文件中的主机名改成 dg2.andylhz.com 实例名改成dgc

如下:

#注意,这里的监听文件需要使用静态注册,否则客户端连接辅助数据库连接不上。所以不能使用动态链接方式。

#listener.ora

[oracle@dg2 admin]$ more /u01/app/oracle/10g/network/admin/listener.ora

# listener.ora Network Configuration File: /u01/app/oracle/10g/network/admin/listener.ora

# Generated by Oracle configuration tools.

 

SID_LIST_LISTENER =

  (SID_LIST =

    (SID_DESC =

      (SID_NAME = PLSExtProc)

      (ORACLE_HOME = /u01/app/oracle/10g)

      (PROGRAM = extproc)

    )

    (SID_DESC =

      (GLOBAL_DBNAME = dgc)

      (ORACLE_HOME = /u01/app/oracle/10g)

      (SID_NAME = dgc)

    )

  )

 

LISTENER =

  (DESCRIPTION_LIST =

    (DESCRIPTION =

      (ADDRESS = (PROTOCOL = TCP)(HOST = dg2.andylhz.com)(PORT = 1521))

      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))

    )

  )


#tnsnames.ora

[oracle@dg2 admin]$ more /u01/app/oracle/10g/network/admin/tnsnames.ora

# tnsnames.ora Network Configuration File: /u01/app/oracle/10g/network/admin/tnsnames.ora

# Generated by Oracle configuration tools.

DGC =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = dg2.andylhz.com)(PORT = 1521))

    )

    (CONNECT_DATA =

      (SERVICE_NAME = dgc)

    )

  )


EXTPROC_CONNECTION_DATA =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))

    )

    (CONNECT_DATA =

      (SID = PLSExtProc)

      (PRESENTATION = RO)

    )

  )

 

3、创建相应的目录:

mkdir –p  /u01/app/oracle/oradata/dgc

mkdir –p  /u01/app/oracle/admin/dgc/adump

mkdir –p  /u01/app/oracle/admin/dgc/bdump

mkdir –p  /u01/app/oracle/admin/dgc/cdump

mkdir –p  /u01/app/oracle/admin/dgc/ddump

mkdir –p  /u01/app/oracle/admin/dgc/udump

mkdir –p  /u01/app/oracle/flash_recovery_area  

 

4、启动dg2监听 

 

5、创建spfile参数文件并启动dg2实例到nomount状态

6、在dg1上使用rman创建一个全库备份,并传输到dg2的相应目录

7win7系统数据库客户端的监听配置

测试连通性:

8、执行复制,线连接到目标数据库,然后在连接到辅助数据库:

9、执行duplicate命令复制


RMAN>duplicate target database to dgc;

详细输出内容请参考:

http://andylhz2009.blog.51cto.com/728703/769170

10、验证:




     本文转自andylhz 51CTO博客,原文链接:http://blog.51cto.com/andylhz2009/771481,如需转载请自行联系原作者


相关文章
|
2天前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
17 3
|
27天前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
15天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—异常断电导致Oracle数据库数据丢失的数据恢复案例
Oracle数据库故障: 机房异常断电后,Oracle数据库启库报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。数据库没有备份,归档日志不连续。用户方提供了Oracle数据库的在线文件,需要恢复zxfg用户的数据。 Oracle数据库恢复方案: 检测数据库故障;尝试挂起并修复数据库;解析数据文件。
|
15天前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
47 2
|
1月前
|
Oracle 安全 关系型数据库
Oracle数据恢复—Oracle数据库误删除的数据恢复方法探讨
删除Oracle数据库数据一般有以下2种方式:delete、drop或truncate。下面针对这2种删除oracle数据库数据的方式探讨一下oracle数据库数据恢复方法(不考虑全库备份和利用归档日志)。
|
1月前
|
存储 Oracle 关系型数据库
Oracle同一台服务器创建多个数据库
【8月更文挑战第30天】在 Oracle 中,可在同一服务器上创建多个数据库。首先确保已安装 Oracle 软件并具有足够资源,然后使用 DBCA 工具按步骤创建,包括选择模板、配置存储及字符集等。重复此过程可创建多个数据库,需确保名称、SID 和存储位置唯一。创建后,可通过 Oracle Enterprise Manager 进行管理,注意服务器资源分配与规划。
49 10
|
19天前
|
SQL Oracle 关系型数据库
Oracle数据库管理:从入门到精通
表(Table):表是Oracle数据库中存储数据的基本结构单元,由行(Row)和列(Column)组成。每行代表一个记录,每列代表一个字段。 SQL(Structured Query Language):SQL是Oracle数据库的核心语言,用于与数据库交互,执行查询、插入、更新和删除等操作。 数据库实例与数据库:在Oracle中,数据库实例是一组后台进程和内存结构,用于管理数据库并提供服务。而数据库则是数据的物理存储,包括数据文件、控制文件、联机日志和参数文件等。
46 0
|
6天前
|
存储 关系型数据库 MySQL
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景比较
|
2天前
|
缓存 算法 关系型数据库
Mysql(3)—数据库相关概念及工作原理
数据库是一个以某种有组织的方式存储的数据集合。它通常包括一个或多个不同的主题领域或用途的数据表。
18 3
Mysql(3)—数据库相关概念及工作原理
|
5天前
|
SQL 关系型数据库 MySQL