多租户:在oracle12.2中从non-cdb迁移到pdb,从pdb迁移另一个cdb中

author author     2022-10-22     791

关键词:

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克隆的步骤**
/*
1、在目标端跟容器中,必须拥有CREATE PLUGGABLE DATABASE的权限。
2、源端数据库 (PDB or non-CDB)必须开启read-only模式。
3、目标端数据库须有一个database link链接源端数据库,如果是PBD,database link使用普通用户指向源端CDB或者PDB用目标端或普通用户
4、源数据库的database link用户必须拥有CREATE PLUGGABLE DATABASE权限。
5、目标数据库和源数据库必须拥有相同的安装选项和字符集;
6、克隆前必须配置TDE;
7、目标端CDB中必须存在源端的默认表空间。如果不存在,新的PDB只能用restricted 模式打开。
8、克隆Non-CDB时,源端和目标端的数据库必须使用12.1.0.2以上版本。
*/

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 [email protected]_link;



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

create pluggable database pdb5new from [email protected]_link;



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

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



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

alter pluggable database pdb5new 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 [email protected]_link;



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

create pluggable database db12cpdb from [email protected]_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工具在目标端进行扫描,并实施相关补丁。

多租户:oracledatabase19c中的dbcapdb远程克隆(代码片段)

OracleDatabase12c第2版(12.2)引入了使用该CREATEPLUGGABLEDATABASE命令执行远程可插拔数据库(PDB)热克隆的功能。在Oracle19c中,可以使用数据库配置助手(DBCA)执行可插拔数据库(PDB)的远程克隆。一、先决条件连接到远程CDB并准备克隆:... 查看详情

oracle12c多租户家族(12c18c19c)如何在pdb中添加hr模式(代码片段)

 Oracle12c多租户家族(12c[12.2.0.1]、18c[12.2.0.2]、19c[12.2.0.3])如何在PDB中添加模式:19c(19.3)手工添加示例HR用户Oracle12c如何在PDB中添加SCOTT模式(手工方式)Oracle12c如何在PDB中添加SCOTT模式(数据泵方式)目录1.配置TNSNAMES.ora2.连... 查看详情

多租户和多应用怎么对应

参考技术A定义软件多租户是一个软件架构,软件只有一个实例运行在服务器上,并服务于多个租户。一个租户包含一组用户,他们拥有指定权限,共同访问一个软件示例。一个多租户架构,应用程序未每个租户提供一个专属于... 查看详情

如何确保租户在共享数据库的多租户中永远无法访问其他租户的数据

】如何确保租户在共享数据库的多租户中永远无法访问其他租户的数据【英文标题】:Howtoensurethattenantscanneveraccessothertenants\'datainmulti-tenantwithshareddb【发布时间】:2022-01-2310:04:21【问题描述】:我正在使用共享数据库实现多租户... 查看详情

如何在多租户应用程序中更新所有租户的所有架构?

】如何在多租户应用程序中更新所有租户的所有架构?【英文标题】:HowupdateinaMultiTenantappallschemaofalltenants?【发布时间】:2011-02-2709:37:28【问题描述】:我正在开发一个多租户应用程序。我选择了“共享数据库/单独架构”方法... 查看详情

架构02-构建多租户(代码片段)

01-什么是多租户:多租户应用是指一个应用同时服务于多个独立的租户(用户、客户、组织等),每个租户的数据都是隔离的。开发多租户应用需要在架构设计、数据存储、权限管理等方面做一些特殊处理。以下是一些建议,可... 查看详情

oracleclouddatabasemigrationandintegration认证备考

...itenantRMANMigrationStrategy这里的AWSRDS实际是Oracle数据库,Non-CDB。AWSRDS不提供操作系统级别访问。RMAN恢复后,还需要转换成PDB&#x 查看详情

oracleclouddatabasemigrationandintegration认证备考

...itenantRMANMigrationStrategy这里的AWSRDS实际是Oracle数据库,Non-CDB。AWSRDS不提供操作系统级别访问。RMAN恢复后,还需要转换成PDB&#x 查看详情

abpzero多租户管理

ABPZero-多租户管理启用多租户ASP.NETBoilerplate和module-zero可以运行多租户或单租户模式。多租户默认为禁用。我们可以在我们的模块PreInitialize方法启用它,使之如下所示:[DependsOn(typeof(AbpZeroCoreModule))]publicclassMyCoreModule:AbpModule{ &... 查看详情

在使用弹簧数据存储库之前更改当前模式 - 多租户

】在使用弹簧数据存储库之前更改当前模式-多租户【英文标题】:ChangecurrentschemabeforeusingspringdataRepository-Multitenancy【发布时间】:2021-01-2802:30:19【问题描述】:我正在使用一个多租户SpringBootWeb应用程序,它从数据库中读取一些... 查看详情

使用 Hyn/多租户在 Laravel 项目中设置测试

】使用Hyn/多租户在Laravel项目中设置测试【英文标题】:SettinguptestinginLaravelprojectusingHyn/multi-tenant【发布时间】:2020-11-2203:30:49【问题描述】:我正在使用Hyn/multi-tenant5.6包来支持多租户应用程序。我的应用程序运行良好,我可以... 查看详情

在多租户应用程序中如何检查应用程序在 Azure 门户中注册的租户数据?

】在多租户应用程序中如何检查应用程序在Azure门户中注册的租户数据?【英文标题】:InamultitenantapplicationHowcanIchecktenantdatawheretheapplicationisregisteredintheazureportal?【发布时间】:2019-08-1716:48:13【问题描述】:我有2个来自不同组织... 查看详情

django 上多租户应用程序的最佳架构

】django上多租户应用程序的最佳架构【英文标题】:optimalarchitectureformultitenantapplicationondjango【发布时间】:2011-11-0321:25:47【问题描述】:我一直在思考创建基于多租户应用程序的正确/最佳方式在Django上。一些解释:应用程序可... 查看详情

多租户改造(代码片段)

一、多租户概念1.多租户是什么意思?怎么理解?​多租户是一种单个软件实例可以为多个不同用户组提供服务的软件架构。在云计算中,多租户也可以指共享主机,其服务器资源将在不同客户之间进行分配。与... 查看详情

为啥 Docker 不支持多租户?

】为啥Docker不支持多租户?【英文标题】:Whydoesn\'tDockersupportmulti-tenancy?为什么Docker不支持多租户?【发布时间】:2017-06-1608:50:07【问题描述】:我看了thisYouTubevideoonDocker,在22:00演讲者(一位Docker产品经理)说:"你可能在想\'Do... 查看详情

运行工匠队列:在动态多租户多数据库系统上工作

】运行工匠队列:在动态多租户多数据库系统上工作【英文标题】:runartisanqueue:workondynamicmultitenantmultidatabasesystem【发布时间】:2021-11-2215:52:04【问题描述】:我正在使用laravel8,并在laravel中开发了一个多租户应用程序。我的应... 查看详情

Spring Boot - 多租户 - 优化 API 的响应时间

】SpringBoot-多租户-优化API的响应时间【英文标题】:SpringBoot-Multitenancy-OptimiseresponsetimeforAPI【发布时间】:2021-03-1816:41:11【问题描述】:我有一个SpringBoot应用程序,它实现了多模式多租户。在没有多租户的情况下,相同的API响应... 查看详情

如何使用 Java Spring 在 MySql 中实现多租户 [关闭]

】如何使用JavaSpring在MySql中实现多租户[关闭]【英文标题】:HowcanIachievemultitenancyinMySqlbyusingJavaSpring[closed]【发布时间】:2018-02-2605:13:48【问题描述】:如何使用MySqlJavaSpring最佳实践实现多租户,并建议使用任何其他数据库代替MyS... 查看详情