Oracle 12c 新特性之 Multitenant Architecture (一)

 

1、 Multitenant Environment直译为多租户环境,是12c的一个新特性,是众多新特性中的一个亮点,我们可以使用这个特性创建一个多租户的容器(container database)CDB来管理多个用户创建的数据库(pluggable database)PDB,这个PDB就是直接为用户服务的数据库,包含schemas objects等信息,在12c之前的数据库都是non-CDB的。

CDB包含以下组件:

Root: 

也称作CDB$ROOT,负责存储元数据和通用账户信息,通用账户能访问所有的PDB,并且一

个CDB中只能有一个root

Seed:

全名PDB$SEED,是我们创建PDB的模板库,我们不能修改里面的数据,他是只读的,一个

CDB中也只能有一个seed

PDBs

        这个就是我们直接使用的数据库了,我们可以使用他来存数据做运算等等,到这一层的使用

        就和以前一样了。

上面所说的就是一个CDB里的所有组件了,每个组件称作一个容器(container),并且每个容器都有一个唯一ID和名称,下面就是一个CDB的架构图

其中root  seed pdb就是我们上面讲到的,大家如果用过SQLSERVER或PostGresql就不会感觉陌生了,其实他更像Postgresql(因为对Postgresql更熟悉,哈哈)

 Oracle 12c 新特性之 Multitenant Architecture (一)_第1张图片

上图描述的比较形象,PDB和root连接的地方被画成了插板,他表示PDB是可插拔的,是不是想到了MySQL中的存储引擎?这和那功能差不多,我们可以在root上加载一个PDB(plugPDB)或者卸载一个PDB(unpluggedPDB),当卸载一个PDB时会生成一个XML的描述文件,包含诸如DATAFILE

一类的信息,当然卸载下来的数据库也可以加载到其他的CDB中,是不是感觉很爽?和SQLSERVER附加数据库的功能差不多,天下文章一大抄啊。

每一个PDB都包含一个全局唯一标识(GUID),主要用来生成包含PDB文件的目录。

 

你可能感兴趣的:(oracle,数据库)