首页 / 数据库 / MySQL / Oracle 11gR2使用RMAN duplicate复制数据库——active database duplicate
Oracle 11gR2的RMAN duplicate 个人感觉比10g的先进了很多,10g需要在rman备份的基础上进行复制,使用 RMAN duplicate 创建一个数据完全相同但DBID不同的数据库。而11g的RMAN duplicate 可以通过Active database duplicate和Backup-based duplicate两种方法实现。这里的测试使用的是Active database duplicate,因为Active database duplicate 功能强大,不需要先把目标数据库进行rman备份,只要目标数据库处于归档模式下即可直接通过网络对数据库进行copy,且copy完成后自动open数据库。这对于大数据特别是T级别的数据库来说优点非常明显,复制前不需要进行备份,减少了备份和传送备份的时间,同时节省备份空间。下面来进行具体的duplicate操作。应用场景:1、旧库可以使用并且网络顺畅实验环境:target db:ip 192.168.56.10oracle_sid=mydboracle_version=11.2.0.3auxiliary db:ip 192.168.56.150oracle_sid=oraduoracle_version=11.2.0.31、在新库创建参数文件并启动实例到nomount状态--auxiliary db上执行[oracle@localhost ~]$ cat initoradu.oradb_name=oradudb_block_size=8192db_file_name_convert=("/u01/app/oracle/oradata/mydb/","/u01/app/oracle/oradata/oradu/")log_file_name_convert=("/u01/app/oracle/oradata/mydb/","/u01/app/oracle/oradata/oradu/")--由于这里使用的是不同实例,所以必须添加db_file_name_convert和log_file_name_convert,否则在复制的时候会报错无法创建数据文件,如果是同实例名复制,且两数据目录完全一样的情况下,这两个参数可省略。--在auxiliary db 上创建新库的数据文件在存放的目录mkdir -p /u01/app/oracle/oradata/oradu/[oracle@localhost ~]$ export ORACLE_SID=oradu[oracle@localhost ~]$ sqlplus / as sysdbaSQL*Plus: Release 11.2.0.3.0 Production on Sun Mar 20 12:56:36 2016Copyright (c) 1982, 2011, Oracle. All rights reserved.Connected to an idle instance.SQL> startup nomount pfile=/home/oracle/initoradu.oraORACLE instance started.Total System Global Area 238034944 bytesFixed Size 2227136 bytesVariable Size 180356160 bytesDatabase Buffers 50331648 bytesRedo Buffers 5120000 bytesSQL>2、创建密码文件--必须保持target DB和auxiliary DB的密码一致。这里我直接把target db的密码文件复制到auxiliary db对应的目录下并重命名--target db上执行[oracle@localhost ~]$ scp /u01/app/oracle/product/11.2.0/db/dbs/orapwmydb oracle@192.168.56.150:/u01/app/oracle/product/11.2.0/db/dbs/orapworaduThe authenticity of host "192.168.56.150 (192.168.56.150)" can"t be established.RSA key fingerprint is 58:71:ed:0c:e0:2a:57:68:3e:fe:79:52:8b:72:2e:00.Are you sure you want to continue connecting (yes/no)? yesWarning: Permanently added "192.168.56.150" (RSA) to the list of known hosts.oracle@192.168.56.150"s password:orapwmydb 100% 1536 1.5KB/s 00:00 3、配置target db 和auxiliary db的监听--auxiliary db必须使用静态监听,否则报错RMAN-04006: error from auxiliary database: ORA-12528: TNS:listener: all appropriate instances are blocking new connections--auxiliary dbvi /u01/app/oracle/product/11.2.0/db/network/admin/listener.oraSID_LIST_LISTENER =(SID_LIST = (SID_DESC = (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db) (SID_NAME=oradu) ))vi /u01/app/oracle/product/11.2.0/db/network/admin/tnsnames.oramydb =(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.10)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = mydb) (SERVER = DEDICATED) )) --target dbvi /u01/app/oracle/product/11.2.0/db/network/admin/listener.oraSID_LIST_LISTENER =(SID_LIST = (SID_DESC = (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db) (ORACLE_SID = mydb) ))vi /u01/app/oracle/product/11.2.0/db/network/admin/tnsnames.oraoradu =(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.150)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = oradu) (SERVER = DEDICATED) ))--重启两台机器的监听lsnrctl stoplsnrctl start4、开始复制--在target db上执行[oracle@localhost ~]$ rman target / auxiliary sys/123456@oraduRecovery Manager: Release 11.2.0.3.0 - Production on Sun Mar 20 14:09:39 2016Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.connected to target database: MYDB (DBID=2820637901)connected to auxiliary database: ORADU (not mounted)RMAN> duplicate target database to oradu from active database;Starting Duplicate Db at 20-MAR-16using target database control file instead of recovery catalogallocated channel: ORA_AUX_DISK_1channel ORA_AUX_DISK_1: SID=20 device type=DISKcontents of Memory Script:{ sql clone "create spfile from memory";}executing Memory Scriptsql statement: create spfile from memorycontents of Memory Script:{ shutdown clone immediate; startup clone nomount;}executing Memory ScriptOracle instance shut downconnected to auxiliary database (not started)Oracle instance startedTotal System Global Area 238034944 bytesFixed Size 2227136 bytesVariable Size 180356160 bytesDatabase Buffers 50331648 bytesRedo Buffers 5120000 bytescontents of Memory Script:{ sql clone "alter system set db_name = ""MYDB"" comment= ""Modified by RMAN duplicate"" scope=spfile"; sql clone "alter system set db_unique_name = ""ORADU"" comment= ""Modified by RMAN duplicate"" scope=spfile"; shutdown clone immediate; startup clone force nomount backup as copy current controlfile auxiliary format "/u01/app/oracle/product/11.2.0/db/dbs/cntrloradu.dbf"; alter clone database mount;}executing Memory Scriptsql statement: alter system set db_name = ""MYDB"" comment= ""Modified by RMAN duplicate"" scope=spfilesql statement: alter system set db_unique_name = ""ORADU"" comment= ""Modified by RMAN duplicate"" scope=spfileOracle instance shut downOracle instance startedTotal System Global Area 238034944 bytesFixed Size 2227136 bytesVariable Size 180356160 bytesDatabase Buffers 50331648 bytesRedo Buffers 5120000 bytesStarting backup at 20-MAR-16allocated channel: ORA_DISK_1channel ORA_DISK_1: SID=34 device type=DISKchannel ORA_DISK_1: starting datafile copycopying current control fileoutput file name=/u01/app/oracle/product/11.2.0/db/dbs/snapcf_mydb.f tag=TAG20160320T140956 RECID=31 STAMP=906991797channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03Finished backup at 20-MAR-16database mountedcontents of Memory Script:{ set newname for datafile 1 to "/u01/app/oracle/oradata/oradu/system01.dbf"; set newname for datafile 2 to "/u01/app/oracle/oradata/oradu/sysaux01.dbf"; set newname for datafile 3 to "/u01/app/oracle/oradata/oradu/undotbs01.dbf"; set newname for datafile 4 to "/u01/app/oracle/oradata/oradu/users01.dbf"; set newname for datafile 5 to "/u01/app/oracle/oradata/oradu/test.dbf"; set newname for datafile 6 to "/u01/app/oracle/oradata/oradu/store_01.dbf"; set newname for datafile 7 to "/u01/app/oracle/oradata/oradu/store_02.dbf"; set newname for datafile 8 to "/u01/app/oracle/oradata/oradu/pitr01.dbf"; backup as copy reuse datafile 1 auxiliary format "/u01/app/oracle/oradata/oradu/system01.dbf" datafile 2 auxiliary format "/u01/app/oracle/oradata/oradu/sysaux01.dbf" datafile 3 auxiliary format "/u01/app/oracle/oradata/oradu/undotbs01.dbf" datafile 4 auxiliary format "/u01/app/oracle/oradata/oradu/users01.dbf" datafile 5 auxiliary format "/u01/app/oracle/oradata/oradu/test.dbf" datafile 6 auxiliary format "/u01/app/oracle/oradata/oradu/store_01.dbf" datafile 7 auxiliary format "/u01/app/oracle/oradata/oradu/store_02.dbf" datafile 8 auxiliary format "/u01/app/oracle/oradata/oradu/pitr01.dbf" ; sql "alter system archive log current";}executing Memory Scriptexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEexecuting command: SET NEWNAMEStarting backup at 20-MAR-16using channel ORA_DISK_1channel ORA_DISK_1: starting datafile copyinput datafile file number=00001 name=/u01/app/oracle/oradata/mydb/system01.dbfoutput file name=/u01/app/oracle/oradata/oradu/system01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:01:05channel ORA_DISK_1: starting datafile copyinput datafile file number=00002 name=/u01/app/oracle/oradata/mydb/sysaux01.dbfoutput file name=/u01/app/oracle/oradata/oradu/sysaux01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:45channel ORA_DISK_1: starting datafile copyinput datafile file number=00003 name=/u01/app/oracle/oradata/mydb/undotbs01.dbfoutput file name=/u01/app/oracle/oradata/oradu/undotbs01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:25channel ORA_DISK_1: starting datafile copyinput datafile file number=00004 name=/u01/app/oracle/oradata/mydb/users01.dbfoutput file name=/u01/app/oracle/oradata/oradu/users01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:15channel ORA_DISK_1: starting datafile copyinput datafile file number=00007 name=/u01/app/oracle/oradata/mydb/store_02.dbfoutput file name=/u01/app/oracle/oradata/oradu/store_02.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03channel ORA_DISK_1: starting datafile copyinput datafile file number=00005 name=/u01/app/oracle/oradata/mydb/test.dbfoutput file name=/u01/app/oracle/oradata/oradu/test.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03channel ORA_DISK_1: starting datafile copyinput datafile file number=00006 name=/u01/app/oracle/oradata/mydb/store_01.dbfoutput file name=/u01/app/oracle/oradata/oradu/store_01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:07channel ORA_DISK_1: starting datafile copyinput datafile file number=00008 name=/u01/app/oracle/oradata/mydb/pitr01.dbfoutput file name=/u01/app/oracle/oradata/oradu/pitr01.dbf tag=TAG20160320T141004channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03Finished backup at 20-MAR-16sql statement: alter system archive log currentcontents of Memory Script:{ backup as copy reuse archivelog like "/u01/app/oracle/product/11.2.0/db/dbs/arch/1_22_906314379.dbf" auxiliary format "/u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbf" ; catalog clone archivelog "/u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbf"; switch clone datafile all;}executing Memory ScriptStarting backup at 20-MAR-16using channel ORA_DISK_1channel ORA_DISK_1: starting archived log copyinput archived log thread=1 sequence=22 RECID=44 STAMP=906991972output file name=/u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbf RECID=0 STAMP=0channel ORA_DISK_1: archived log copy complete, elapsed time: 00:00:01Finished backup at 20-MAR-16cataloged archived logarchived log file name=/u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbf RECID=44 STAMP=906989788datafile 1 switched to datafile copyinput datafile copy RECID=31 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/system01.dbfdatafile 2 switched to datafile copyinput datafile copy RECID=32 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/sysaux01.dbfdatafile 3 switched to datafile copyinput datafile copy RECID=33 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/undotbs01.dbfdatafile 4 switched to datafile copyinput datafile copy RECID=34 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/users01.dbfdatafile 5 switched to datafile copyinput datafile copy RECID=35 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/test.dbfdatafile 6 switched to datafile copyinput datafile copy RECID=36 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/store_01.dbfdatafile 7 switched to datafile copyinput datafile copy RECID=37 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/store_02.dbfdatafile 8 switched to datafile copyinput datafile copy RECID=38 STAMP=906989788 file name=/u01/app/oracle/oradata/oradu/pitr01.dbfcontents of Memory Script:{ set until scn 2809336; recover clone database delete archivelog ;}executing Memory Scriptexecuting command: SET until clauseStarting recover at 20-MAR-16allocated channel: ORA_AUX_DISK_1channel ORA_AUX_DISK_1: SID=18 device type=DISKstarting media recoveryarchived log for thread 1 with sequence 22 is already on disk as file /u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbfarchived log file name=/u01/app/oracle/product/11.2.0/db/dbs/arch1_22_906314379.dbf thread=1 sequence=22media recovery complete, elapsed time: 00:00:01Finished recover at 20-MAR-16Oracle instance startedTotal System Global Area 238034944 bytesFixed Size 2227136 bytesVariable Size 180356160 bytesDatabase Buffers 50331648 bytesRedo Buffers 5120000 bytescontents of Memory Script:{ sql clone "alter system set db_name = ""ORADU"" comment= ""Reset to original value by RMAN"" scope=spfile"; sql clone "alter system reset db_unique_name scope=spfile"; shutdown clone immediate; startup clone nomount;}executing Memory Scriptsql statement: alter system set db_name = ""ORADU"" comment= ""Reset to original value by RMAN"" scope=spfilesql statement: alter system reset db_unique_name scope=spfileOracle instance shut downconnected to auxiliary database (not started)Oracle instance startedTotal System Global Area 238034944 bytesFixed Size 2227136 bytesVariable Size 180356160 bytesDatabase Buffers 50331648 bytesRedo Buffers 5120000 bytessql statement: CREATE CONTROLFILE REUSE SET DATABASE "ORADU" RESETLOGS ARCHIVELOGMAXLOGFILES 16MAXLOGMEMBERS 3MAXDATAFILES 100MAXINSTANCES 8MAXLOGHISTORY 292 LOGFILEGROUP 1 ( "/u01/app/oracle/oradata/oradu/redo01.log", "/u01/app/oracle/oradata/oradu/redo01_01.log" ) SIZE 100 M REUSE,GROUP 2 ( "/u01/app/oracle/oradata/oradu/redo02.log", "/u01/app/oracle/oradata/oradu/redo02_01.log" ) SIZE 100 M REUSE,GROUP 3 ( "/u01/app/oracle/oradata/oradu/redo03.log", "/u01/app/oracle/oradata/oradu/redo03_01.log" ) SIZE 100 M REUSE,GROUP 4 ( "/u01/app/oracle/oradata/oradu/redo04.log", "/u01/app/oracle/oradata/oradu/redo04_01.log" ) SIZE 100 M REUSE DATAFILE"/u01/app/oracle/oradata/oradu/system01.dbf" CHARACTER SET ZHS16GBKcontents of Memory Script:{ set newname for tempfile 1 to "/u01/app/oracle/oradata/oradu/temp01.dbf"; switch clone tempfile all; catalog clone datafilecopy "/u01/app/oracle/oradata/oradu/sysaux01.dbf", "/u01/app/oracle/oradata/oradu/undotbs01.dbf", "/u01/app/oracle/oradata/oradu/users01.dbf", "/u01/app/oracle/oradata/oradu/test.dbf", "/u01/app/oracle/oradata/oradu/store_01.dbf", "/u01/app/oracle/oradata/oradu/store_02.dbf", "/u01/app/oracle/oradata/oradu/pitr01.dbf"; switch clone datafile all;}executing Memory Scriptexecuting command: SET NEWNAMErenamed tempfile 1 to /u01/app/oracle/oradata/oradu/temp01.dbf in control filecataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/sysaux01.dbf RECID=1 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/undotbs01.dbf RECID=2 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/users01.dbf RECID=3 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/test.dbf RECID=4 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/store_01.dbf RECID=5 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/store_02.dbf RECID=6 STAMP=906989800cataloged datafile copydatafile copy file name=/u01/app/oracle/oradata/oradu/pitr01.dbf RECID=7 STAMP=906989800datafile 2 switched to datafile copyinput datafile copy RECID=1 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/sysaux01.dbfdatafile 3 switched to datafile copyinput datafile copy RECID=2 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/undotbs01.dbfdatafile 4 switched to datafile copyinput datafile copy RECID=3 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/users01.dbfdatafile 5 switched to datafile copyinput datafile copy RECID=4 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/test.dbfdatafile 6 switched to datafile copyinput datafile copy RECID=5 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/store_01.dbfdatafile 7 switched to datafile copyinput datafile copy RECID=6 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/store_02.dbfdatafile 8 switched to datafile copyinput datafile copy RECID=7 STAMP=906989800 file name=/u01/app/oracle/oradata/oradu/pitr01.dbfReenabling controlfile options for auxiliary databaseExecuting: alter database add supplemental log datacontents of Memory Script:{ Alter clone database open resetlogs;}executing Memory Scriptdatabase openedFinished Duplicate Db at 20-MAR-16RMAN>5、验证是否迁移成功--在auxiliary db 执行SQL> select name,open_mode from v$database;NAME OPEN_MODE--------- --------------------ORADU READ WRITE更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12本文永久更新链接地址