oracle cdb、pdb参考
admin
2023-04-14 21:21:18
0
CDB、PDB概念介绍

CDB与PDB是Oracle 12C引入的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为Container Database,中文翻译为数据库容器,PDB全称为Pluggable Database,即可插拔数据库。在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC):即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。而实例与数据库不可能是一对多的关系。当进入ORACLE 12C后,实例与数据库可以是一对多的关系。下面为CDB与PDB的关系图:

oracle cdb、pdb参考

一个CDB容器数据库通常包含CDB$ROOT、PDB$SEED组件:
a. CDB$ROOT存储着ORACLE提供的元数据和Common User,Common User 是指在每个容器中都存在的用户,查看:

show con_name;

oracle cdb、pdb参考
b.PDB$SEED是创建PDB数据库的模板。一个CDB中有且只能有一个Seed,查看:

show pdbs

oracle cdb、pdb参考
c.PDB可插拔数据库,CDB中可以有一个或多个PDB,查看:

show pdbs

oracle cdb、pdb参考

创建CDB容器数据库

dbca在创建数据库的时候,可以选择是创建容器数据库还是传统的数据库,如下图选择为创建CDB:

oracle cdb、pdb参考

创建pdb:

a.命令create pluggable database创建:

create pluggable database app1 admin user pdba identified by pdba123;

oracle cdb、pdb参考

指定路径创建pdb:

mkdir -p /u01/app/oracle/oradata/prod/data

create pluggable database app1 admin user pdba identified by pdba123 FILE_NAME_CONVERT=('/u01/app/oracle/oradata/prod/pdbseed','/u01/app/oracle/oradata/prod/data');

oracle cdb、pdb参考

b.dbca创建pdb:

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

oracle cdb、pdb参考

确认:

oracle cdb、pdb参考

启动pdb:

alter pluggable database APP1 open;

oracle cdb、pdb参考

c. 克隆pdb数据库:

alter system set db_create_file_dest='/u01/app/oracle/oradata/prod/';

oracle cdb、pdb参考

create pluggable database app3 from app2;

oracle cdb、pdb参考

删除pdb

先关闭对应的pdb,然后删除pdb:

alter pluggable database app3 close immediate;

drop pluggable database app3 including datafiles;

oracle cdb、pdb参考

只是删除库,不删除文件:

drop pluggable database app3 keep datafiles;

oracle cdb、pdb参考

alter pluggable database app3 unplug into '/home/oracle/app3.xml';

oracle cdb、pdb参考

drop pluggable database app3 keep datafiles;

show pdbs

oracle cdb、pdb参考

create pluggable database app5 using '/home/oracle/app3.xml' nocopy;

oracle cdb、pdb参考

切换容器

切换到app1 pdb下面:

alter session set container=app1;

oracle cdb、pdb参考
切换到CDB容器

alter session set container=CDB$ROOT;   

oracle cdb、pdb参考

查看当前属于哪个容器:

show con_name

oracle cdb、pdb参考

select sys_context('USERENV','CON_NAME') from dual;

oracle cdb、pdb参考

启动、关闭pdb

a. 指定pdb进行关闭和启动:

alter pluggable database app1 open;

oracle cdb、pdb参考

startup pluggable database app1;

oracle cdb、pdb参考

启动到只读模式,新建的pdb必须启动一次后才可以设置为read only,否则报

ERROR at line 1:

ORA-65085: cannot open pluggable database in read-only mode:

可以从dba_pdbs视图进行确认,对于NEW的pdb,需要先open:

SQL> col pdb_name for a10

SQL> select pdb_name,status from dba_pdbs;

PDB_NAME STATUS

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

APP1 NORMAL

PDB$SEED NORMAL

APP2 NORMAL

APP3 NORMAL

APP4 NEW

新建一个app3 数据库,然后执行启动到read only:

create pluggable database app3 from app2;

oracle cdb、pdb参考

alter pluggable database app3 open read only;

oracle cdb、pdb参考

alter pluggable database app3 open read only;

show pdbs;

oracle cdb、pdb参考

alter pluggable database app1 close immediate;

oracle cdb、pdb参考

b.切换到对应的pdb进行关闭启动:
alter session set container= app1; 

startup;

oracle cdb、pdb参考

alter session set container= app1;

shutdown immediate;

oracle cdb、pdb参考

c.集中操作pdb:

开启所有pdb:

alter pluggable database all open; 

oracle cdb、pdb参考

关闭所有pdb:

alter pluggable database all close immediate;

oracle cdb、pdb参考

pdb自动启动:

oracle 12.1和oracle12.2版本,默认情况下PDB不会随着CDB启动而启动,oracle 12.1只能通过触发器实现:

CREATE TRIGGER open_all_pdbs

AFTER STARTUP ON DATABASE

BEGIN

EXECUTE IMMEDIATE 'ALTER PLUGGABLE DATABASE ALL OPEN';

END ;

/

删除触发器:

drop trigger open_all_pdbs;

oracle12.2之后可以使用save state来保存pdb数据库的当前状态。

show pdbs;

alter pluggable database app1 save state;

oracle cdb、pdb参考

startup force;

show pdbs;

oracle cdb、pdb参考

查看state状态:

col con_name for a10

select con_name, state from dba_pdb_saved_states;

oracle cdb、pdb参考

删除discard state状态:

alter pluggable database app1 discard state;

oracle cdb、pdb参考

查看pdb信息

查看所有pdb:
show pdbs

oracle cdb、pdb参考

col name for a20

select con_id,dbid,name,open_mode from v$pdbs;

oracle cdb、pdb参考

select name,cause ,type,message,status from pdb_plug_in_violations;

相关内容

热门资讯

官方调查报告:司机吸食打火机气... 11日,辽阳市应急管理局发布辽阳灯塔沈营线(S101)“10·8”较大道路运输事故调查报告。2024...
赖清德窜访媚外,金门老百姓却苦... 探访厦金大桥赖清德“偷渡式”窜访,岛内民众大骂:这边民生受阻,那边你还去给外国人“跪”。反观今年4月...
特朗普访华,通用汽车和福特高层... 【文/观察者网 潘昱辰 编辑/高莘】美国总统特朗普将于5月13-15日对中国进行国事访问。据白宫披露...
还是谈不成,特朗普没招了 作者 | 谢奕秋 编辑 | 阿树美伊新一轮的和平提议交换,至5月10日宣告无果而终。伊朗对美国提案的...
网传“45岁独身男子病逝15万... 近日,南京一位老人照顾独身病侄,侄子离世后15万存款被转走的事件引发广泛关注。5月12日,针对网传“...
亚太经合组织电信工作组第72次... 来源:上海证券报·中国证券网 上证报中国证券网讯 据工业和信息化部5月12日消息,5月11日,亚太经...
银星能源获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示银星能源(000862)新获得一项实用新型专利授权,专利名为“...
特朗普访华在即,随行商界大咖都... 美国总统特朗普将于5月13日至15日对中国进行国事访问。这是中美两国元首继去年10月釜山之后再次面对...
有线电视机顶盒安装问题求安装方... 有线电视安装说明: 一、将白色有线电视线一端连接有线电视终端盒另一端连接机顶盒后的射频输入口。 ...
60寸电视机尺寸画面长宽是多少...   60寸的液晶电视,60寸就是指电视屏幕对角线长度,因为长宽比有两种情况,经过寸转化为厘米计算之后...