文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

多租户:在Oracle12.2中 从Non-CDB迁移到PDB,从PDB迁移另一个CDB中

2024-04-02 19:55

关注

1、从PDB或者Non-CDB迁移到另一个CDB的PDB准备

从PDB或者Non-CDB迁移到CDB容器数据库中PDB,由于PDB和Non-CDB迁移到CDB的步骤几乎相同,PDB和Non-CDB迁移非常相似,共同进行处理。
准备:
CDB1:目标pdb数据库的容器数据库
db12c: 需要迁移的Non-CDB
CDB3: 需要迁移pbd的容器数据库

2、在Oracle DB12C克隆远程PDB或者Non-CDB
--注:local代表目的或者目标CDB端,remote代表PBD或者Non-CDB 的源端。
**--2.1克隆的步骤**


2.2 克隆Remote PDB
--1.设置环境

export ORAENV_ASK=NO
export ORACLE_SID=cdb3
. oraenv
export ORAENV_ASK=YES
sqlplus / as sysdba



--2.在remote端创建用户,用于db_link

alter session set container=pdb5;
create user remote_clone_user identified by remote_clone_user;
grant create session,create pluggable database to remote_clone_user;



--3.在remote端的PDB中打开read only模式

conn / as sysdba
alter pluggable database pdb5 close;
alter pluggable database pdb5 open read only;
exit;



--4.在local端的“tnsnames.ora”中添加本地链接名称,供db_link使用

PDB5 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.2.81)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = pdb5)
    )
  )


 
--5.连接local端开始克隆

export ORAENV_ASK=NO
export ORACLE_SID=cdb1
. oraenv
export ORAENV_ASK=YES
sqlplus / as sysdba



--6.在local端创建数据库连接

drop database link clone_link;
create database link clone_link connect to remote_clone_user identified by remote_clone_user using 'pdb5';



--测试连接

desc user_tables@clone_link;



--7.在local端数据库创建新的PDB

create pluggable database pdb5new from pdb5@clone_link;



--8、查看新的PDB和其状态

select name,open_mode from v$pdbs where name='PDB5NEW';



--9、以read-write模式打开PDB

alter pluggable database pdbsnew open;
select name,open_mode from v$pdbs where name ='PDB5NEW';



**--2.3 克隆Non-CDB**
--1.设置环境

export ORAENV_ASK=NO
export ORACLE_SID=db12c
. oraenv
export ORAENV_ASK=YES
sqlplus / as sysdba

--2.在remote端创建用户,用于db_link

create user remote_clone_user identified by remote_clone_user;
grant create session,create pluggable database to remote_clone_user;

--3.在remote端的PDB中打开read only模式

shutdown immediate;
startup mount;
alter database read only;
exit;



--4.在local端的“tnsnames.ora”中添加本地链接名称,供db_link使用

DB12C =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.93)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = PDF)
    )
  )


 
--5.连接local端开始克隆

export ORAENV_ASK=NO
export ORACLE_SID=cdb1
. oraenv
export ORAENV_ASK=YES
sqlplus / as sysdba



--6.在local端创建数据库连接

drop database link clone_link;
create database link clone_link connect to remote_clone_user identified by remote_clone_user using 'db12c';



--测试连接

desc user_tables@clone_link;



--7.在local端数据库创建新的PDB

create pluggable database db12cpdb from NON$CDB@clone_link;



--8.查看新的PDB和其状态

select name,open_mode from v$pdbs where name='DB12CPDB';



--9.运行以下脚本清除non-CDB到PDB信息

alter session set container=db12cpdb;
@$ORACLE_HOME/rdbms/admin/noncdb_to_pdb.sql



--10.以read-write模式打开PDB

ALTER PLUGGABLE DATABASE db12cpdb OPEN;
select name,open_mode from v$pdbs where name ='DB12CPDB';



**--2.4 将non-cdb数据库迁移到位PDB**

--1.关闭non-cdb并以read-only模式打开

export ORACLE_SID=db12c
sqlplus / as sysdba
shutdown immediate;
startup open read only;



--2.使用dbms_pbd.describe过程创建xml文件

begin
  dbms_pdb.describe(
        pdb_descr_file =>'/tmp/db12c.xml');
end;



--3.关闭non-cdb数据库

exprot ORACLE_SID=db12c
sqlplus / as sysdba
shutdown immediate;



--4.使用non-cdb的描述文件在CDB中创建PDB

export ORACLE_SID=cdb1
sqlplus / as sysdba
craete pluggable database pdb6 using '/tmp/db12c.xml'
copy
file_name_convert =('/u01/app/oracle/oradata/db12c/', '/u01/app/oracle/oradata/cdb1/pdb6/');



--5.切换到pdb6,运行如下脚本

alter session set container = pdb6;
@$ORACLE_HOME/rdbms/admin/noncdb_to_pdb.sql



--6.启动PDB,检查open_mode

alter session set container =pdb6;
alter pluggable database open ;
select name,open_mode from v$pdbs;



**--2.5 数据迁移**
--方案一:使用 data dump (expdp/impdp)
--使用 data dump (expdp/impdp)从non-cdb迁移到新创建的PDB数据库中。如果non-cdb是11.2.0.3以上的版本以下的版本,expdp使用"FULL=Y TRANSPORTABLE=ALWAYS VERSION=12"参数。如果在不同的平台进行转换需要使用RMAN的convert命令,或者DBMS_FILE_TRANSFER包。

--方案二:使用Goldengate
--使用Goldengate的replicate将数据从non-cdb传输到pdb上。

**--2.6 补丁考虑**
--如果源端和目标端的补丁基本不一样,需要从PDB的PDB_PLUG_IN_VIOLATIONS试图中查看,并且使用datapatch工具在目标端进行扫描,并实施相关补丁。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯