oracle克隆pdb,ORACLE_CDB/PDB克隆迁移转换

Oracle 12c PDB/CDB相关测试

1. 本地克隆pdb

1.1 环境检查

源环境和目标环境执行

数据库版本12.2.0.1.0.

$ sqlplus / as sysdba

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 TESTCLONEPDB              MOUNT NO

1.2 环境克隆

$ sqlplus / as sysdba

SQL> alter session set container= TESTCLONEPDB;

Session altered.

SQL> alter database open read only;

Database altered.

SQL > exit;

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 TESTCLONEPDB              READ WRITE NO

SQL> exit

SQL> create pluggable database testpdb from ORCLPDB file_name_convert=('orclpdb','testpdb');

Pluggable database created.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 TESTCLONEPDB              READ WRITE NO

5 TESTPDB                   MOUNTED

SQL> alter session set container= TESTPDB;

Session altered.

SQL> show pdbs

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

5 TESTPDB                   MOUNTED

SQL> alter database open;

Database altered.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

5 TESTPDB                   READ WRITE NO

2. 跨服务器克隆pdb

2.1 本地复制异地进行插入方式

2.1.1 源环境克隆

源端执行:

$ sqlplus / as sysdba

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

SQL>

SQL> alter pluggable database ORCLPDB close;

Pluggable database altered.

SQL> alter pluggable database ORCLPDB open read only;

Pluggable database altered.

SQL> create pluggable database ORCLPDB_clone from ORCLPDB

2  file_name_convert=('/u02/app/oracle/oradata/orcl/orclpdb/','/u02/app/oracle/oradata/orcl/orclpdb_clone/');

Pluggable database created.

SQL> alter pluggable database ORCLPDB close;

Pluggable database altered.

SQL> alter pluggable database ORCLPDB open;

Pluggable database altered.

SQL> alter pluggable database ORCLPDB_clone open;

Pluggable database altered.

2.1.2 源环境导出XML文件

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 ORCLPDB_CLONE            READ WRITE NO

SQL> alter pluggable database ORCLPDB_CLONE close;

Pluggable database altered.

SQL> alter pluggable database ORCLPDB_CLONE unplug into '/u02/app/oracle/oradata/orcl/orclpdb_clone/orclpdb_clone.xml';

Pluggable database altered.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 ORCLPDB_CLONE            MOUNTED

2.1.3 复制文件到目标环境

-- 目标端执行

在目标端创建与源端一致的数据文件路径;

$ mkdir -p /u02/app/oracle/oradata/orcl/orclpdb_clone

$ mkdir -p /u02/app/oracle/oradata/TEST/orclpdb/

$ cd /u02/app/oracle/oradata/orcl/orclpdb_clone

$ scp root@192.168.1.161:/u02/app/oracle/oradata/orcl/orclpdb_clone/* .

2.1.4 目标环境插入PDB

-- 目标端执行

[oracle@pdb2 orclpdb]$ sqlplus / as sysdba

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 TESTPDB                   READ WRITE NO

SQL> create pluggable database orclpdb_clone using '/u02/app/oracle/oradata/orcl/orclpdb_clone/orclpdb_clone.xml'

2  file_name_convert=('/u02/app/oracle/oradata/orcl/orclpdb_clone/','/u02/app/oracle/oradata/TEST/orclpdb/')

3  copy;

Pluggable database created.

2.1.5 检查目标环境

-- 目标端执行

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 TESTPDB                   READ WRITE NO

5 ORCLPDB_CLONE            MOUNTED

SQL> alter pluggable database ORCLPDB_CLONE open;

Pluggable database altered.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 TESTPDB                   READ WRITE NO

5 ORCLPDB_CLONE            READ WRITE NO

2.1.6 删除源环境的备份

-- 在源端执行

$ sqlplus / as sysdba

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 ORCLPDB_CLONE            MOUNTED

SQL> drop pluggable database ORCLPDB_CLONE;

Pluggable database dropped.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

-- 在源端执行

$ cd /u02/app/oracle/oradata/orcl

$ ls -al orclpdb_clone

$ rm -rf orclpdb_clone

2.2 dblink方式

2.2.1 源端创建用户

--源端

SQL> show pdbs;

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 DEMOPDB                READ WRITE NO

4 TESTPDB                   READ WRITE NO

SQL> create user c##andy identified by andy container=all;

User created.

SQL> grant dba to c##andy container=all;

Grant succeeded.

2.2.2 目标端创建DBLINK

-- 目标端cdb执行

SQL> create database link clonepdb connect to c##andy identified by andy using '(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.165)(PORT = 1522))(CONNECT_DATA=(SERVER = DEDICATED)(SERVICE_NAME =demo)))';

Database link created.

2.2.3 目标端执行克隆

-- 目标端cdb

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

SQL> alter session set pdb_file_name_convert='testpdb','testclonepdb';

Session altered.

-- 通过 dblink 克隆源端的 pdb

SQL> create pluggable database testclonepdb from TESTPDB@clonepdb;

Pluggable database created.

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 TESTCLONEPDB              MOUNTED

SQL>

SQL> alter pluggable database TESTCLONEPDB open;

Pluggable database altered.

2.2.4 检查目标环境

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCLPDB                 READ WRITE NO

4 TESTCLONEPDB              READ WRITE NO

3. NO CDB转换成CDB

3.1 源环境检查

SQL> select name, decode(cdb, 'YES', 'Multitenant Option enabled', 'Regular 12c Database: ') "Multitenant Option" , open_mode, con_id from v$database;

NAME      Multitenant Option       OPEN_MODE                  CON_ID

--------- -------------------------- -------------------- ----------

DEV   Regular 12c Database:      READ WRITE             0

SQL> select name from v$datafile;

NAME

--------------------------------------------------------------------------------

/u01/app/oracle/oradata/DEV/system01.dbf

/u01/app/oracle/oradata/DEV/sysaux01.dbf

/u01/app/oracle/oradata/DEV/undotbs01.dbf

/u01/app/oracle/oradata/DEV/users01.dbf

3.2 搭建目标数据库

c43f898b7805de36751609c6a4d7e78b.png

3.3 迁移

源环境

SQL> shutdown immediate;

SQL> alter database open read only;

SQL> begin

dbms_pdb.describe(PDB_DESCR_FILE => '/u01/test/ DEV.xml');

end;

/

目标环境

SQL> create pluggable database ORCL using '/u01/test/DEV.xml' file_name_convert=('/u01/app/oracle/oradata/DEV','/u01/app/oracle/oradata/ORCL/ORCLpdb');

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCL                       MOUNTED

SQL> alter session set container=ORCL;

Session altered.

SQL>

SQL> @?/rdbms/admin/noncdb_to_pdb.sql

SQL> alter pluggable database ORCL open;

3.4 目标环境检查

SQL> show pdbs;

CON_ID CON_NAME                   OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

2 PDB$SEED                READ ONLY  NO

3 ORCL                       READ WRITE NO

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值