《第二章:Oracle 体系结构概述》

《第二章:Oracle体系结构概述》

定义数据库和实例

  • 数据库: 操作系统文件或磁盘(disk)的集合。在12c中,Oracle提供了三种不同类型的数据库,包括单租户数据库,容器(根)数据库,可插拔式数据库。
  • 单租户数据库:这种数据库包含所有的数据文件,控制文件,重做日志文件,参数文件等。(Oracle 12c之前都是这种数据库)
  • 容器数据库(Container Database ,CDB): 数据库存在一整套数据文件,控制文件,重做日志文件等,但仅用于存放数据库** 元数据**和数据库自用数据=数据库自包含,不依赖其他对象即可被实例挂载(mount)和打开(open)=
  • 可插拔式数据库(Pluggable Database,PDB):仅包含数据文件,需要插入CDB容器数据库中才能使用,没有控制日志参数文件等。
  • 实例:一组后台进程(线程)以及一个共享内存区域(PGA+SGA)

容器数据库+可插拔数据库=单租户数据库

实例和数据库关系

  • 单租户(或容器)数据库,一个实例对应一个数据库,一个数据库可以背多个实例打开。(实例在生命周期内只能打开一个数据库);
  • 对于可插拔式数据库: 他在任何时间点只能和一个容器(CDB)关联;一个CDB可同时挂在多个PDB(约为250个)
  • 一个实例可以同时打开多个PDB(数据文件),这些PDB归属于同一个CDB(数据库控制文件)

链接Oracle

  • 连接数据库分为两种方式专用服务器连接(dedicated server)和共享连接(shared server )。监听程序Listener用于建立服务器于客户端的TCP/IP连接。
  • 专用服务器:在登陆的时候为创建新的进程,为我们服务,该进程不属于实例,他负责这行我们提交的SQL调用数据库数据。这个服务器进程唯一的目标就是为我们提交的SQL作出响应
  • 共享服务器:数据库不会为每个连接创建一个单独的进程或线程(PGA位于SGA中)。不必为每个用户单独创建进程,使得它能服务更多的客户
  • 两者的区别: 共享服务器中用户无法直接于专用服务器进行通讯,而是通过和调度进程通讯来工作。调度程序会不断的监听查看当前服务器进程情况。

可插拔式数据库

  • CDB存放Oracle运行时所需的的必要信息,PDB中存放剩下的数据与元数据。
  • 实例首先装载和打开CDB,在完成之后,实例可以打开PDB。每个PDB像一个独立的数据库,但他们实际上共享一个数据库实例和容器。

可插拔数据库的优点

  • 降低资源用量:一个数据库实例大约需要20-40个进程(线程),在单用户模式下,同时打开多个数据库将带来巨大的系统开销。此外,每个实例有独立但一样的SGA结构。通过PDB有效的== 分离==数据,用户代码等。
  • 降低维护开销:降低DBA的维护工作量,如果同时对50个单租户数据库进行升级维护,将分别对每一个数据库进行升级操作,而可插拔式数据库将之需要升级维护一次就行。
  • PDB将有效降低服务器的资源用量和DBA的管理工作。
  • 用户可以分为全局CDB的和PD的,PDB可以看到CDB用户但是,不可以看到其他CDB数据
  • 数据独立性更好
  • 临时表空间可以是全局或本地的
  • redu和undo是全局的
  • 同一个PDB可以在不同的CDB中进行插拔,备份升级
  • 数据库字典分为全局和本地的

小结

你可能感兴趣的:(笔记)