oracle体系结构总结
描述oracle数据库体系结构的组成及其关系。

描述oracle数据库体系结构的组成及其关系。
Oracle数据库体系结构由以下几个部分组成:1. 实例(Instance):实例是在计算机内存中运行的一个进程,负责管理数据库的操作。
每个实例都有自己的内存空间和进程,可以同时运行多个实例。
2. 数据库(Database):数据库是一个存储数据的容器,包含了表、视图、索引等对象。
一个实例可以管理多个数据库,每个数据库由一个或多个数据文件组成。
3. 数据文件(Data File):数据文件是用来存储数据库的实际数据的文件,包含了表、索引等对象的数据。
一个数据库可以有多个数据文件,每个数据文件具有独立的文件名和路径。
4. 控制文件(Control File):控制文件是用来记录数据库的结构和状态信息的文件,包括数据库名、数据文件的路径、表空间的信息等。
一个数据库通常有一个或多个控制文件。
5. 日志文件(Redo Log File):日志文件是用来记录数据库的变化操作的文件,包括数据更改、事务回滚等。
日志文件用于实现数据库的恢复和数据的一致性。
每个数据库通常有多个日志文件。
6. 表空间(Tablespace):表空间是数据库中逻辑数据存储的单位,用来管理和组织对象。
每个表空间由一个或多个数据文件组成,不同表空间可以包含不同的数据对象。
7. 段(Segment):段是逻辑存储结构的基本单位,是指数据库中的一个连续空间。
每个表、索引等对象都占用一个或多个段。
8. 区(Extent):区是段的扩展单位,是一组连续的数据块。
一个段由多个区组成。
9. 块(Data Block):块是数据库存储的最小单位,通常是8KB大小。
每个数据文件由多个块组成。
以上组成部分之间的关系如下:- 实例与数据库:一个实例可以管理多个数据库,每个数据库都有自己的实例。
- 数据库与数据文件:一个数据库可以由一个或多个数据文件组成,每个数据文件存储数据库的实际数据。
- 实例与控制文件:一个实例通常有一个或多个控制文件,控制文件记录了数据库的结构和状态信息。
(参考资料)oracle 体系结构详解

oracle 体系结构详解一、体系结构图oracle实例=SGA区+后台进程oracle服务器=oracle实例+oracle数据库数据库实例启动实质上即为:分配SGA区,启动后台进程Oracle 实例1、是访问Oracle 数据库的一种方式2、通常只开一个且仅开一个数据库3、由内存结构和进程结构组成,即SGA区+后台进程连接Oracle实例:包括建立用户连接和创建会话Oracle数据库是作为整体的数据集,由三类文件组成:Data files, Control files, Redo log files二、物理结构主要由三类文件组成:data files ,control files,redo-log files1.data files:数据文件,存放基本表信息(即表中数据等)、索引信息(系统内建有索引表)、回退信息(主要为数据的rollback)、临时信息(如有orderby 等操作时系统有临时信息)、系统引导信息(如数据字典等)2、control files:控制文件(二进制的)。
存放库物理结构、库名、库创建日期、序列号(存有同步信息);控制文件至少有两个一摸一样的,用做备份用参数Controlfiles=/../../文件名1,/../../文件名2;指定3、redo log files:回退日志文件,存放修改前后的信息,主要用于数据的恢复,一个数据库至少有两个redo log files文件,以便可以循环记录信息注:三类文件都有序列号,必须同步才能使用,且已Control files中的序列号为准,其他的必须与其保持一致除了上面三类文件还有:Parameter file(参数文件),Password file(口令文件),Archived log files(归档文件)等参数文件:有二进制、文本两种,用于设定参数的值。
二进制参数文件可以及时更改,即时生效;文本参数文件需重启口令文件:可用orapwd.exe 建口令文件。
oracle体系结构总结.

oracle体系结构总结.传统上Oracle体系结构由内存结构、进程结构、存储结构组成。
其中,内存结构由SGA、PGA组成;进程结构由用户进程和Oracle 进程组成;存储结构由逻辑存储、物理存储组成。
通过数据库的启动过程和一条sql的执行过程可以将oracle的内存结构、进程结构、存储结构串起来。
一、内存结构(1)SGA(System Global Area):一个包含实例数据和控制信息的共享内存区域(2)PGA(Program Global Area):一个包含服务器进程和后台进程的数据和控制信息的共享内存区域1.1系统全局区SGA系统全局区,是DB Server 中实例的必要组成部分,由很多小内存区共同构成,各个小内存区存放不同的信息,系统全局区用于暂存可以被所有进程(包括server process 以及background process)共享的信息,对系统的运行性能有好处,SGA 在实例启动的时候自动分配,实例关闭时自动释放。
SGA 暂存系统的大量共享数据,对系统有相当的性能影响,所以需要为SGA 选择适当的管理方式,根据所使用的数据库版本不同,SGA 的管理有三种方式:1)8i:SGA 的大小由所有内存组件大小之和决定,不能直接定义 SGA 大小,对内存组件的大小可后台进行修改,但只能通过直接修改参数文件的内存参数大小,而且修改完数据库必须重起后才能生效,所以这种内存管理方法叫做 SGA 的静态管理。
2)9i:SGA 的大小由初始化参数SGA_MAX_SIZ E 确定,各个内存组件大小之和不能超过这个参数。
可以直接通过命令进行修改内存组件大小而不用重启,这种叫做 SGA 的动态管理3)10g:SGA 大小既可以像 9i 一人样动态管理,也可以实施 SGA 的自动管理,默认是SGA 的自动管理,启用SGA 自动管理只需要设置初始化参数 SGA_TARGET 即可,各个组件大小之和不超过 SGA _TARGET 。
oracle 体系结构

三、oracle 体系结构1、oracle内存由SGA+PGA所构成2、oracle数据库体系结构数据库的体系结构是指数据库的组成、工作过程与原理,以及数据在数据库中的组织与管理机制。
oracle工作原理:1)、在数据库服务器上启动Oracle实例;2)、应用程序在客户端的用户进程中运行,启用Oracle网络服务驱动器与服务器建立连接;3)、服务器运行Oracle网络服务驱动器,建立专用的服务器进程执行用户进程;4)、客户端提交事务;5)、服务器进程获取sql语句并检查共享池中是否有相似的sql语句,如果有,服务器进程再检查用户的访问权限;否则分配新的sql共享区分析并执行sql语句;6)、服务器从实际的数据文件或SGA中取得所需数据;7)、服务器进程在SGA中更新数据,进程DBWN在特定条件下将更新过的数据块写回磁盘,进程LGWR在重做日志文件中记录事务;8)、如果事务成功,服务器进程发送消息到应用程序中。
3、oracle服务器i、oracle服务器由oracle数据库和oracle实例组成。
ii、oracle数据库是一个数据的集合,存放在数据文件里,该集合被视为一个逻辑单元。
iii、oracle实例由管理数据库的后台进程和内存结构所构成。
4、oracle实例i、Oracle实例是内存结构和后台进程的集合ii、启动Oracle实例的过程,即:分配内存、启动后台进程iii、Oracle实例的内存包括SGA和PGA;当启动实例的时候分配SGA;当服务器进程建立时分配PGA;一般情况下,SGA:PGA=8:1分配内存。
iiii、Oracle实例的后台进程包括SMON、PMON、DBWR、LGWR、ARC、CKPT等。
5、SGA(System Global Area): 系统全局区i0、数据库信息存储于SGA,由多个数据库进程共享。
i1、SGA包括:共享池、数据缓冲区、日志缓冲区、Large池、Java池、Stream池。
Oracle数据库体系结构

Oracle数据库体系结构⼀、oracle数据库体系结构基本组成:Oracle server:⼀般情况下是⼀个instance和⼀个database组成⼀般:1个instance只能对应⼀个数据库。
特殊:1个数据库可以有多个instance(RAC)⼀台服务器上同时可装多套版本的数据库软件,每个数据库软件可建多个数据库,但是每个数据库只对应⼀个instance,也可以理解成每个数据库只有⼀个SID 。
利⽤DBCA建出的每个库都是相对独⽴的,在同⼀服务器上如果创建多库必须将环境变量的参数⽂件做区分,并且在对实例切换时需如下操作:connect ⽤户名/密码@实例的服务名1.1 oracle服务器和实例1.1.1实例由内存区和后台进程组成①内存区:数据库⾼速缓存、重做⽇志缓存、共享池、流池以及其它可选内存区(如Java池),这些池也称为数据库的内存结构②后台进程:包括系统监控进程(SMON)、进程监控(PMON)、数据库写进程(DBWR)、⽇志写进程(LGWR)、检验点进程(CKPT)、其它进程(SMON,如归档进程、RECO进程等)③注:要访问数据库必须先启动实例,实例启动时先分配内存区,然后再启动后台进程,后台进程执⾏库数据的输⼊、输出以及监控其它Oracle进程。
在数据库启动过程中有五个进程是必须启动的,它们是系统监控进程(SMON)、进程监控(PMON)、数据库写进程(DBWR)、⽇志写进程(LGWR)、检验点进程(CKPT),否则实例⽆法创建。
1.1.2服务器Oracle服务器由数据库实例和数据⽂件组成,也就是我们常说的数据库管理系统。
数据库服务器除了维护实例和数据库⽂件之外,还在⽤户建⽴与服务器的连接时启动服务器进程并分配PGA1.2 oracle数据库逻辑结构表空间:据库的基本逻辑结构,是⼀系列数据⽂件的集合;段:不同类型数据在数据库中占⽤的空间,有许多区组合⽽成;区:由连续的块组成,⽬的是为数据⼀次性预留⼀个较⼤的空间,oracle为存储空间进⾏分配回收都是以区为单位的;块:最⼩的存储单位,在创建数据库时指定,不能修改。
Oracle数据库体系结构

Oracle数据库体系结构一.Oracle数据库体系结构1.实例:一组用于管理数据库文件的内存结构,实例对应着数据库;RAC/CDB CDB:CDB为数据库容器,PDB插拔数据库。
在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC),即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。
而实例与数据库不可能是一对多的关系。
当进入ORACLE 12C后,实例与数据库可以是一对多的关系。
RAC:允许多个Oracle数据库实例在多台服务器上共享同一个数据库存储空间,并通过集群来保证高可用性和容错性。
简单来说,RAC就是将多个数据库实例连接起来,形成一个“集群”。
2.ShardingSphere:中间件,不同的数据库对应不同的实例,中间有一个中间件,使用者连接中间件;数据库中间件可以简化对读写分离以及分库分表的操作,并隐藏底层实现细节,可以像操作单库单表那样操作多库多表。
常见的中间件有MyCat,Mysql-Proxy,DRDS,Atlas,Zebra二.Orcal数据库体系结构:Orcal服务器=数据库+实例1.实例是暂时的,它只不过是一组逻辑划分的内存结构和进程结构,它会随着数据的关闭而消失数据库它就是一堆物理文件(控制文件、数据文件、日志文件等等)它呢是永久存在的数据库和实例是一对一的,这种结构我们一般称为单实例体系结构;既然有一对一,那就会有一对多,在复杂的分布式结构中,一个数据库可以对多个实例,多个实例之间可以通过网络来进行数据的一个交互或着交换2.PGA:程序全局区,为单独的服务器进程存储私有数据的内存区域(SAG属于公共资源,PAG是私有的)3.SGA:系统全局区,所有用户都可以访问的共享内存区域启动Oracle数据库时,系统先在内存内规划一个固定区域,用来储存用户需要的数据,以及Oracle运行时必备的系统信息4.后台进程结构,此处只罗列必须启动的5个后台进程系统监控器SMON:负载检查数据库一致性,有必要会在数据库打开时启动数据库恢复进程监视器PMON:负责一个Orcal数据库进程失败时清理资源,会定期唤醒或者被其他主动事务主动唤醒数据库写进程DBWR:负责将更改的数据从“数据库高速缓冲区”写入“数据文件”日志写进程LGWR:负载把日志数据写到练级日志文件检查点进程SKPT:负责检查点操作,主要检查数据库状态一致性和记录系统变更时间5.三个文件1)控制文件:存储数据库结构,一个控制文件只属于一个数据库,包含数据文件日志文件信息及相关状态归档信息,2)数据文件:存储数据,xxx.dbf文件存储着系统数据,数据字典数据,索引数据及用户存储的数据3)日志文件:存储与事务有关的重做日志三.逻辑存储结构1.块是Oracle用来管理存储的最小单元,也是最小的逻辑存储结构2.区是Oracle数据库分配空间的最小单位3.段由多个区组成,这些区可以是连续的,也可以是不连续的4.表空间是Oracle数据库的最大逻辑划分区域,通常用来存放数据表、索引、回滚段等数据对象。
简述oracle体系结构

简述oracle体系结构
Oracle体系结构
Oracle是一种支持分布式数据库管理系统,其体系结构主要包
括E-R图,表和索引,存储过程和视图, SQL,PL/SQL程序和组件,等等。
1. E-R图
E-R图是一种关系数据库管理系统的基本模型,其中实体表示客观事物,关系表示实体之间的联系。
E-R图可以被用来描述实体和它们之间的关系,以及实体的属性和它们之间的关系。
2.表和索引
表是由一系列列组成的逻辑结构,它们包含每行和每列的数据。
索引是一种特别的表,可以被用来提高表的搜索速度和性能。
3.存储过程和视图
存储过程是一种特定类型的程序,它们可以被用来完成某些操作,比如查询和更新。
视图是一种准备好的查询,它们可以被用来返回数据库中的数据。
4.SQL,PL/SQL程序和组件
SQL(Structured Query Language)是一种用于在数据库中执行查询和更新操作的语言,是一种面向关系型数据库的核心语言。
PL/SQL是一种可以嵌入SQL语句的程序设计语言,用来定义复杂的
查询,更新和实现回调函数。
组件是一种模块化的程序,用来构建更复杂的系统。
Oracle体系结构

Oracle体系结构⼀、Oracle DB服务器体系结构概览。
Oracle DB 服务器体系结构包含以下三种主要结构:内存结构、进程结构和存储结构。
基本的 Oracle DB 系统由 Oracle DB 和数据库实例组成。
数据库包括物理结构和逻辑结构。
由于物理结构和逻辑结构是分开的,因此管理数据的物理存储时不会影响对逻辑存储结构的访问。
实例由与该实例关联的内存结构和后台进程构成。
每当启动⼀个实例时,都会分配⼀个称为系统全局区 (SGA) 的共享内存区,并启动后台进程。
进程是在计算机的内存中运⾏的作业。
进程被定义为操作系统中可运⾏⼀系列步骤的“控制线程”或机制。
启动数据库实例后,Oracle 软件会将该实例与特定数据库相关联。
该操作称为“装载数据库”。
之后⽤户可以打开数据库,即授权⽤户可以对其进⾏访问。
注:Oracle ⾃动存储管理 (ASM) 在管理内存和进程组件时使⽤实例概念,不与特定数据库关联。
访问数据库⽤户并不是数据库⽤户,是某⼀个⽤户下⾯acount表。
连接:⽤户进程和实例之间的通信。
会话:⽤户通过⽤户进程与实例之间建⽴的特定连接。
会话中包含很多事务,事物的状态是commit、rollback。
1.Oracle内存结构Oracle DB 创建并使⽤内存结构来满⾜多种需要。
例如,使⽤内存来存储正在运⾏的程序代码、在各⽤户之间共享的数据以及所连接的每个⽤户的专⽤数据区域。
⼀个实例有两个关联的基本内存结构:程序全局区 (PGA) :包含某个服务器进程或后台进程的数据及控制信息的内存区域。
PGA 是 Oracle DB 在服务器进程或后台进程启动时创建的⾮共享内存。
服务器进程对PGA 的访问是独占式的。
每个服务器进程和后台进程都具有⾃⼰的 PGA。
PGA主要⽤于存放会话连接信息,排序操作(order by)帮助数据库减轻处理SQL的压⼒。
系统全局区 (SGA) :⼀组共享的内存结构(称为 SGA 组件),其中包含⼀个 Oracle DB 实例的数据和控制信息。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
oracle体系结构总结传统上Oracle体系结构由内存结构、进程结构、存储结构组成。
其中,内存结构由SGA、PGA组成;进程结构由用户进程和Oracle进程组成;存储结构由逻辑存储、物理存储组成。
通过数据库的启动过程和一条sql的执行过程可以将oracle的内存结构、进程结构、存储结构串起来。
一、内存结构(1)SGA(System Global Area):一个包含实例数据和控制信息的共享内存区域(2)PGA(Program Global Area):一个包含服务器进程和后台进程的数据和控制信息的共享内存区域1.1系统全局区SGA系统全局区,是DB Server 中实例的必要组成部分,由很多小内存区共同构成,各个小内存区存放不同的信息,系统全局区用于暂存可以被所有进程(包括server process 以及background process)共享的信息,对系统的运行性能有好处,SGA 在实例启动的时候自动分配,实例关闭时自动释放。
SGA 暂存系统的大量共享数据,对系统有相当的性能影响,所以需要为SGA 选择适当的管理方式,根据所使用的数据库版本不同,SGA 的管理有三种方式:1)8i:SGA 的大小由所有内存组件大小之和决定,不能直接定义SGA 大小,对内存组件的大小可后台进行修改,但只能通过直接修改参数文件的内存参数大小,而且修改完数据库必须重起后才能生效,所以这种内存管理方法叫做SGA 的静态管理。
2)9i:SGA 的大小由初始化参数SGA_MAX_SIZ E 确定,各个内存组件大小之和不能超过这个参数。
可以直接通过命令进行修改内存组件大小而不用重启,这种叫做SGA 的动态管理3)10g:SGA 大小既可以像9i 一人样动态管理,也可以实施SGA 的自动管理,默认是SGA 的自动管理,启用SGA 自动管理只需要设置初始化参数SGA_TARGET 即可,各个组件大小之和不超过SGA _TARGET 。
在自动管理下,SGA 各个内存组件由数据库自动设置大小,设置各个内存区大小的依据来源于系统自动收集的统计信息。
在设置内存组件大小的时候,分配的基本单位是粒度(granule )granule 是一段连续的虚拟内存,大小取决于SGA_MAX_SIZE 的大小,如果SGA_MAX_SIZ E小于128M ,Granule 为4M,否则Granule 为16M。
大多数内存组件的大小必须是Granule 的整数倍,Redo Log Buffer 的大小不受这个限制,可以自行设置,它与其他小内存区共同构成Granule 的整数倍。
整个SGA 最小不小于3 个Granule 大小,其中共享池一个,数据缓存区一个,其他分一个,SGA的总大小也一定是Granule 的整数倍大小。
SGA 大多数组件的大小可以动态调整,只要确保所有的内存组件大小之和不超过SGA _MAX_SIZE 或SGA_TARGET 的大小,在10G 中SGA 内存组件可以自动管理,各个内存大小由数据库自己决定,设置SGA_TARGET 参数(非0)即可以开启内存自动管理,这个参数也可动态修改,如果设置为0,则意味着,禁用内存自动管理,伋需要DBA 手动调整各个内存组件大小。
以下内存组件大小可以由数据库自动设置1)Buffer cache(db_cache_size)2)Shared pool(shared_pool_size)3)Large pool(large_pool_size)4)Java pool(java_pool_size)5)Stream pool(stream_pool_size)手动设置:1)LOG_BUFFER2)STREAMS_POOL3)DB_NK_CACHE_SIZE4)DB_KEEP_CACHE_SIZE5)DB_RECYCLE_CACHE_SIZESGA 的必要内存区包括Shared Pool( 共享池)、DB Buffer Cache(数据库高速缓存)Redo Log和Buffers (重做日志缓存区)。
共享池中又包含了库高速缓存(Library Cache)和数据字典高速缓存(Data Dict Cache)其中库高速缓存中暂存了最近常用的SQL 和PL/SQL 语句文件,分析代码,执行计划,用于减少代码的硬解析频度;数据字典高速缓存中暂存了最近常用的数据字典信息,用于为SQL 语句解析提供可以快速读取的数据字典信息。
数据库高速缓存(DB Buffer Cache)暂存最近常用的数据块信息,减少磁盘I/O 操作,用于提高数据访问的速度。
重做日志缓存区暂存最近生成的重做日志,将来批量写到重做日志文件中,这样可以确保日志能够更快的生成,提高DML 操作的执行速度,也能够减少日志带来的写频度。
除了必要内存区外,SGA 也有一些可选的内存区,主要有大池Large Pool)Java 池Java Pool)(,(以及流池(Stream Pool)。
大池主要用于共享模式存放用户全局区(UGA) 的信息,也提供了对Rman 备份恢复以及并行进程的支持。
Java 池的功能类似于共享池,暂存Java 程序的信息。
Stream 池是10G 的新内存区,支持新的流复制技术。
1.1.1共享池(Shared pool)共享池用于缓存sql,plsql、数据字典、资源锁及其它用于控制结构相关的数据,共享池是SGA中最关键的内存片段,特别是在性能和可伸缩性上。
太大太小都会扼杀性能,使系统停止,将会消耗大量的CPU来管理这个共享池。
共享池大小由参数shared_pool_size 决定大小,可以动态调整,它的各个内部件大小由共享池大小决定,不能单独设置alter system shared_pool_size=100m; 设置共享池大小;如果开启了内存自动管理特性,则不需要DBA 手动调整。
共享池主要包括两个与sql 语句解析性能相关的内存组件。
清空缓存池:alter system flush shared_pool;dbms_shared_pool.purge 某个sql共享池可分为:Library Cache和Data Dictionaey Cache1.1.1.1 库高速缓冲区(Library Cache)库高速缓存用于暂存最近常使用的SQL 和PL/SQL 语句的文本,分析代码,执行计划。
SQL 文本也就是SQL 语句。
执行计划是最终SQL 语句的执行算法,分析代码则是生成执行计划的分析过程。
库高速缓存暂时存放常用语句信息的目的是为了能够共享SQL 代码,从而能够重用已经解析好的执行计划,减少硬解析带来的资源消耗与其它内存区一样,库高速缓存也遵循LRU 算法管理内存,由于内存空间大小有限,所以总会有一些SQL 语句的信息被挤出库高速缓存区,这意味着必然会带来一些语句代码的硬解析,所以需要对库高速缓存进行一些调整,以减少对解析性能的影响库高速缓存的内部又分为两个内存区,分别缓存SQL 语句和PL/SQL 语句的信息:共享sql 区共享pl/sql 区库高速缓存的大小不能直接设置,受共享池的大小影响,由数据库自行决定对于保存在共享池中的SQL语句,可以从V$Sqltext、v$Sqlarea中查询到,对于编程者来说,要尽量提高语句的重用率,减少语句的分析时间。
一个设计的差的应用程序可以毁掉整个数据库的Share pool,提高SQL语句的重用率必须先养成良好的变成习惯,尽量使用Bind变量。
1.1.1.2 数据字典高速缓存区(data dict cache)数据字典高速缓存用于暂存最近常使用的数据字典信息,它同样遵循LRU 算法管理内存,在字典缓存区中主要暂存解析所需的表空间,存储,表,索引,字段,用户,权限以及其他数据库对象的相关字典信息。
由于SQL 语句解析时,服务进程需要查找相关的数据字典信息以支持解析,而字典信息默认存储在数据文件的数据字典信息中,所以每次解析去I/O 读取数据文件并不是好的选择。
将常用的字典信息缓存在数据字典高速缓存区中,能够快速访问所需的字典信息,有效减少解析的时间,所以SQL 语句解析的性能得到提高。
数据字典的大小也不能直接修改,受共享池的大小的影响,数据库自行决定1.1.2 数据高速缓存区(db buffer cache)用于暂存从数据文件中获得的数据块的数据映像,同样遵循LRU 算法管理内存,不论是表中的数据块,不是索引的数据块,或回滚段的数据块,都被读取到数据高速缓存中进行处理,如果内存中的数据块发生变化,在特定的时机会被DBWR进程将修改后的数据写回到数据文件中。
由于大量数据块经常被反复访问,所以如果数据已经读入内存,当再次需要操作这些数据块时就可以在内存中直接获取和更新,减少了磁盘I/O 的操作,SQL 语句的执行执行效率有大幅的提高初始化参数DB_BLOCK_SIZE 决定了数据块的大小,这也是数据库I/O 的最小单位,所以这个参数将影响到数据访问的性能,而且需要注意的是,这个参数在创建数据库之后将不能够被改变,数据高速缓区由多个独立的子缓存池构成,它的大小是这些缓存池的大小之和,这些子缓存区可以独立设置大小,通过下面的参数进行设置1)Default db_cache_size2)Keep db_keep_cache_size3)Recycle db_recycle_cache_sizekeep缓存池适合存放常用的数据字典表,可以把这样的表直接keep在keep缓存池中;recycle缓存池,用完就释放,适合存放不常用的大表这些子缓存池的大小都可以动态调整,但是只有db_cache_size 可以由数据库自动管理大小,默认只有db_cache_size 被设置了有效值,其他两个缓存池大小被设置为零1.1.3 重做日志缓冲区(Redo log buffer)重做日志缓冲区用于暂存数据库中所有数据块的改变信息,这些信息将按照改变的发生时间顺序记录在缓存区中,然后在特定的时机下被写入重做日志文件,日志缓存区的内存管理方法是FIFO,也就是是先进先出。
重做日志主要被用于提供数据的恢复功能,应用日志前滚(roll forward)就是数据库的基本恢复原理使用重做日志缓冲区的目的是为了提高DML 或者DDL 语句的执行速度,减少日志产生带来的性能影响,减少系统日志I/O 的频度。
重做日志缓冲区的大小出log_buffer 参数决定,但这个内存区不能动态调整大小,也不能被自动管理。
重做日志缓冲区的存在是因为内存到内存的操作比较内存到硬盘的速度快很多,所以重作日志缓冲区可以加快数据库的操作速度,但是考虑的数据库的一致性与可恢复性,数据在重做日志缓冲区中的滞留时间不会很长。