Oracle体系结构研究
- 格式:doc
- 大小:45.00 KB
- 文档页数:15
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数据库体系结构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是一种支持分布式数据库管理系统,其体系结构主要包
括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 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 实例的数据和控制信息。
Oracle数据库体系结构小结——参考文献:Concepts双语版Oracle数据库体系结构分为四大体系结构,即:Oracle网格体系结构、应用体系结构、物理数据库结构、逻辑数据库结构;一、 Oracle网格体系结构:Oracle是第一个为企业网格计算而设计的数据库。
在网格体系中所有资源被统一储备、随需分配。
回顾网格的相关内容:1、网格将相似的IT资源整体地看做一个池。
2、网格中管理的IT资源包括:基础设施:组成数据存储、软件运行环境的硬件和软件;应用:定义业务过程(business process)的程序逻辑(program logic)和流程(flow);信息:蕴含于各种数据中用于指导业务的数据的内在含义;3、网格中的两个独特核心理念:虚拟化和资源供给;虚拟化,就是将各类独立的资源视为一个池,经过抽象后提供给资源消费者。
这意味着打破了资源提供者与资源消费者之间的硬性联系(也就是说没有明确规定哪一块资源就是某个消费者独有的)。
资源供给,就是当消费者通过虚拟层请求资料时,网格在幕后找出满足需求的资源,并分配给消费者。
注:基础设施、应用、信息三种资源的虚拟化与资源供给的具体方法各不相同,但思路是相通的。
并且通过网格供给三种资源给用户带来的益处也各不相同,但都具备商质量、低造价、及灵活的特点。
将基础设施资源视为一个池并随需分配,提高了资源利用水平,减少了冗余资源,节约了软硬件购买资金。
数据库服务器的网格特性:1、基础设施网格:A、服务能力虚拟化:Oracle实时应用集群(RAC Oracle Real Application Clusters)可以使一个数据库运行在网格中多个集群节点上,即把多个计算机的处理能力作为池。
Oracle是目前唯一不需要将数据分区再分布处理就能利用多个计算机提供的处理能力的数据库。
B、存储能力虚拟化。
Oracle数据库10g的自动存储管理功能(ASM,Automatic Storage Management)在数据库存储硬件之间建立了一个虚拟层,多个磁盘可以被视为一个磁盘组,而且磁盘可以在保持数据库联机的状态下动态地添加或先移除。
Oracle数据库的体系结构介绍Oracle数据库是目前世界领先的企业级关系数据库管理系统,其卓越的性能、可靠性以及安全性被广泛地应用于企业级应用系统中。
本文将详细介绍Oracle数据库的体系结构,帮助读者更好地了解Oracle数据库。
一、概述Oracle数据库的体系结构分为三层:物理层、逻辑层和视图层。
物理层描述了数据在物理介质上的存储方式和管理方式;逻辑层主要由Oracle数据库的核心服务组成,该层体现了Oracle数据库的最核心功能;视图层则提供给应用程序用户和管理员使用,是Oracle数据库的最外层。
二、物理层Oracle数据库的物理层包括数据文件、控制文件和重做日志文件。
其中,数据文件用于存储数据表、索引和其他对象的数据;控制文件则记录了数据库的结构信息和操作日志,是维护数据库一致性和恢复数据的关键元素;重做日志文件用于记录正在进行的操作和已经完成的操作,以便在系统崩溃或停机时进行恢复。
三、逻辑层Oracle数据库的逻辑层包括多个服务组件,如SQL解析器、优化器、缓存池、锁管理器、存储管理器等。
其中,SQL解析器用于解析SQL语句,将其转换成可执行的优化器,并进行语法和语义检查;优化器则负责分析并优化SQL执行计划,以提高查询效率;缓存池用于存储查询结果和表空间等数据对象,提高查询响应速度;锁管理器则负责管理并发访问,防止数据冲突,保证数据库的一致性和稳定性。
四、视图层Oracle数据库的视图层提供了多种视图和接口,包括SQL*Plus、SQL Developer、Toad等。
其中,SQL*Plus是Oracle自带的命令行工具,提供简单的SQL语句执行和结果输出;SQL Developer是Oracle 提供的图形化界面工具,提供更为便捷的数据库管理和开发支持;Toad则是第三方软件,提供了更为强大和灵活的数据库管理和开发支持。
五、总结Oracle数据库作为目前世界领先的企业级关系数据库管理系统,其体系结构设计合理,层次清晰,提供了完备的物理、逻辑和视图三层管理机制,为企业级应用系统提供了高效、可靠、稳定的运行环境和数据服务。
Oracle体系结构Oracle核心竞争力可扩充性:Oracle系统有能力承担增长的工作符合,并且相应的扩充系统资源利用情况。
可靠性:无论出现系统资源崩溃,电源断电还是系统故障的时候,我们都可以对Oracle进行配置。
以保证检索用户数据事务处理的时候,不受到影响。
可管理性:数据库管理员可以微调Oracle使用内存的方式,以及Oracle向磁盘写入数据的频率。
并且管理可以调整,数据库为连接到数据库的用户分配操作系统进程的方式。
Oracle总体结构分为三个部分第一部分:系统全局区(SGA)第二部分:程序全局区和后台进程第三部分:Oracle的文件如果从功能上划分的话:存储结构:由这些文件就构成了Oracle的物理存储结构。
内存结构:使用内存最多的是SGA,也是影响数据库系统性能最大的一个参数。
进程结构:前台进程服务进程和用户进程,是根据实际需要而运行的,并在需要结束后立刻结束。
后台进程是指Oracle数据库启动后自动启动的几个操作系统进程。
存储结构包括物理结构和逻辑结构,既独立又相互联系的。
物理结构:是和操作系统平台有关的。
逻辑结构:逻辑存储结构是和操作系统平台无关的。
_______________________________________________________________________________这个图是两种存储结构中的对应关系表空间包括系统表空间和用户表空间。
表空间也是最大的逻辑单位。
块是最小的一个逻辑单位。
逻辑结构的表空间对应着物理结构的数据文件,也就是创建表空间的时候要给它指定数据文件,但是一个表空间可以对应多个数据文件。
表空间的大小也就是他包含的数据文件大小的总和。
数据文件呢同时又对应着操作系统中的数据块,数据文件也是以数据块的形式,存在于操作系统中。
逻辑结构中的块也对应着操作系统的数据块。
——————————————————————————————————————— 物理存储结构Oracle的物理存储结构,也就是Oracle的数据库文件数据库文件又分为主要文件和其他文件主要文件:首先来看数据文件:就是物理存储Oracle数据库数据的文件有一下特点:◆每一个数据文件,只与一个数据库相关联。
oracle数据库体系架构详解在学习oracle中,体系结构是重中之重,一开始从宏观上掌握它的物理组成、文件组成和各种文件组成。
掌握的越深入越好。
在实际工作遇到疑难问题,其实都可以归结到体系结构中来解释。
体系结构是对一个系统的框架描述。
是设计一个系统的宏观工作。
这好比建一栋大楼。
你首先应该以图纸的方式把整个大楼的体系架构描述出来。
然后一点点的往里面填充东西。
下面我们先以一个图解的方式对oracle体系结构有一个基本了解根据示图,便于我们记忆,示图分三部分组成,左侧User Process、Server Process、PGA可以看做成Clinet端,上面的实例(Instance)和下面的数据库(Database)及参数文件(parameter file)、密码文件(password file)和归档日志文件(archived logfiles)组成Oracle Server,所以整个示图可以理解成一个C/S架构。
Oracle Server由两个实体组成:实例(instance)与数据库(database)。
这两个实体是独立的,不过连接在一起。
在数据库创建过程中,实例首先被创建,然后才创建数据库。
在典型的单实例环境中,实例与数据库的关系是一对一的,一个实例连接一个数据库,实例与数据库也可以是多对一的关系,即不同计算机上的多个实例打开共享磁盘系统上的一个公用数据库。
这种多对一关系被称为实际应用群集(Real Application Clusters,RAC)RAC极大提高了数据库的性能、容错与可伸缩性(可能耗费更多的存储空间)并且是oracle网格(grid)概念的必备部分。
下面我们来详细看一下oracle数据库的体系架构Oracle体系架构主要有两大部分组成:数据库实例(Instance)和数据库文件(database)数据库实例指数据库服务器的内存及相关处理程序,它是Oracle的心脏。
与Oracle 性能关系最大的是SGA(System Global Area,即系统全局区活共享内存区),SGA包含三个部分:1、数据缓冲区,可避免重复读取常用的数据;2、日志缓冲区,提升了数据增删改的速度,减少磁盘的读写而加快速度;3、共享池,使相同的SQL语句不再编译,提升了SQL的执行速度。
Oracle体系结构就是围绕这张图展开的,要想深入了解oracle,就必须把这张图搞明白。
如图:一、基本组成:Oracle server:一般情况下是一个instance和一个database组成1个instance只能对应一个数据库。
特殊:1个数据库可以有多个instance(rac)一台服务器上同时可装多套版本的数据库软件,每个数据库软件可建多个数据库,但是每个数据库只对应一个instance,也可以理解成每个数据库只有一个SID 。
利用DBCA建出的每个库都是相对独立的,在同一服务器上如果创建多库必须将环境变量的参数文件做区分,并且在对实例切换时需如下操作:connect 用户名/密码@实例的服务名Oracle Instance:是由内存(SGA)和后台进程(backupground Process)组成通过instance来访问database一个实例只能打开一个数据库Oracle database:数据文件(Data files):数据文件永远存储数据库的数据,包括数据字典、用户数据(表、索引、簇)、undo数据等重做日志(Redo log):“先记后写”重做日志用于记录数据库的变化,当进行例程恢复或介质恢复时需要使用重做日志执行DDL或DML操作时,事物变化会被写到重做日志缓冲区,而在特定的时刻LGWR会将重做日志缓冲区中的内容写入重做日志。
控制文件(Control file)控制文件用于记录和维护数据库的物理结构,并且每个Oracle数据库至少要包含一个控制文件。
归档日志(Archive log):是非活动(Inactive)重做日志的备份。
口令文件(Password file):用于验证特权用户(具有SYSDBA、SYSOPER权限的特殊数据库用户)参数文件(Parameter file):用于定义启动实例所需要的初始化参数,包括文本参数文件(pfile)和服务器参数文件(spfile)(二进制文件放入裸设备,引入spfile)User and Server process :在执行sql语句时产生的进程,每一个连接,oracle server创建一个session,产生一个server process,在client发起一个connection时就产生了一个user process。
Oracle体系结构详解(上)一、oracle数据库的整体架构由上图可知,oracle数据库由实例和数据库组成。
二、数据库存储结构:2.1数据库存储结构Oracle数据库有物理结构和逻辑结构。
数据库的物理结构是数据库中的操作系统文件的集合。
数据库的物理结构由数据文件、控制文件和重做日志文件组成。
数据文件:数据文件是数据的存储仓库。
联机重做日志文件:联机重做日志文件包含对数据库所做的更改记录,在发生故障时能够恢复数据。
重做日志按时间顺序存储应用于数据库的一连串的变更向量。
其中仅包含重建(重做)所有已完成工作的最少限度信息。
如果数据文件受损,则可以将这些变更向量应用于数据文件备份来重做工作,将它恢复到发生故障的那一刻前的状态。
重做日志文件包含联机重做日志文件(对于连续的数据库操作时必须的)和归档日志文件(对于数据库操作是可选的,但对于时间点恢复是必须的)。
查看系统的redo log的信息SQL> select group#,sequence#,bytes,members,status from v$log;GROUP# SEQUENCE# BYTES MEMBERS STATUS---------- ---------- ---------- ---------- ----------------1 22 52428800 1 INACTIVE2 23 52428800 1 CURRENT3 21 52428800 1 INACTIVESQL> select member from v$logfile;MEMBER/u01/app/oracle/oradata/hnzk/redo03.log/u01/app/oracle/oradata/hnzk/redo02.log/u01/app/oracle/oradata/hnzk/redo01.log控制文件:控制文件包含维护和验证数据库完整性的必要的信息。
Oracle体系结构研究摘要:阐述了Oracle数据库的基本架构和Oracle数据库理论中的主要概念。
Oracle体系结构由存储结构、内存结构和进程结构组成,其中,存储结构由物理存储结构及逻辑存储结构组成;内存结构由SGA和PGA组成;进程结构由用户进程和Oracle进程组成。
关键词:ORACLE体系结构;存储结构;内存结构;进程结构1 Oracle的存储结构Oracle的存储结构分为物理存储结构和逻辑存储结构。
1.1 物理存储结构主要由数据文件、控制文件、联机日志文件及数据库实例构成。
Oracle数据库中有许多初始化参数,这些参数用于对整个数据库进行设置或调整,如设置数据库名、数据库块大小、控制文件的名称和位置、数据库实例数等信息。
Oracle 把这些参数存放在一个文件中,这个文件就叫初始化参数文件。
启动数据库时,Oracle会读取参数文件中的值,并根据这些值对数据库实例(instance)进行设置。
具体说是Oracle先从初始化参数文件中获得控制文件的名称及位置,打开控制文件,然后再从控制文件中读取数据文件和联机日志文件的名称和位置,打开它们,因为表、索引等对象的数据就存放在数据文件中,从而就打开了数据库。
1.1.1 控制文件Oracle启动数据库时会访问控制文件,控制文件是在创建数据库的时候创建的,它是一个很小的二进制文件,记录了数据库的名称、创建数据库的时间、数据文件的名称和位置、联机日志文件的名称和位置及表空间等信息。
所以说一个数据库的控制文件是相当重要的,一旦被损坏,数据库将不能正常启动和运行。
所以DBA应该镜像控制文件,把每个镜像的控制文件分布到不同的物理磁盘上,发生灾难时既使其中一个控制文件被损坏,也不会使整个数据库限于瘫痪。
1.1.2 数据文件当用户在Oracle中创建数据库的时候,就创建了一个或多个数据文件,表和索引等对象的数据就物理地存放在数据文件中。
一个表的数据可能会存储在多个数据文件中,但一个数据文件只能属于一个数据库。
用户查询一个表时,如果所需数据不在内存中,Oracle会读取该表所在的数据文件,并把数据调入内存中,也就是说访问表实际上就是对数据文件进行读写操作。
创建数据文件时可以指定其初始大小,当其空间耗尽时,也可自动或手动扩展其大小。
1.1.3 联机日志文件当用户在内存中对数据库做了修改时(如插入、删除、修改),如果数据还没有来得及写入数据文件中就发生断电,用户的修改就会丢失。
为了防止这种情况的发生,Oracle运行过程中会在内存中产生日志条目,这些日志条目反应了用户所做的修改,并每隔一段时间把日志条目写到物理的联机日志文件中。
重启数据库时,Oracle会从联机日志文件中找回丢失的修改数据并重新把它写到数据文件中。
由此可见,联机日志文件主要用于对数据库实例(Instance)的恢复。
当用户提交一个事务或每隔3秒钟或日志缓冲区被填满1/3时,产生的日志信息就会被写到联机日志文件中。
1.2 逻辑存储结构Oracle 的逻辑存储结构由数据块、区、段和表空间构成。
1.2.1 表空间一个数据库被分成一个个的逻辑单元,这些逻辑单元叫“表空间”。
表空间用于在逻辑上存放数据库对象如表、索引等。
一个数据库逻辑上由一个或多个表空间组成。
表空间又由一个或多个数据文件物理地支持着,表空间中的数据库对象(如表)的数据实际上是存储在数据文件中的。
表空间的大小是组成表空间的所有数据文件的大小之和。
但表和数据文件却不是一一对应的,一个表的数据可以存放在一个或多个数据文件中。
每个数据库用户都要有一个默认表空间,当用户创建对象(如表)时,如果没有指定这个对象放在哪个表空间中,则这个对象将被存放在默认表空间中。
1.2.2 数据块数据块简称块,是Oracle存取数据的最小单位。
Oracle数据存放在块中,一个块占用一定的磁盘空间。
这里的“块”是Oracle 的数据块,而不是操作系统的“块”。
Oracle每次读写数据的时候都以块为单位,如果读写的数据不到一块,Oracle也会读写整个块。
Oracle块的大小一般是操作系统块大小(512bytes)的整数倍,如2k,4k。
块大小由初始化参数文件中的DB_BLOCK_SIZE 参数指定。
1.2.3 区区是数据库中的一个逻辑存储单元,由连续的数据块组成。
特别强调的是区是一段连续的存储空间。
当段中的空间耗尽时,Oracle会分配一个新区给这个段。
段由一系列的区组成,也是存放数据的逻辑单元。
表由段组成,一个表由一个或多个段组成。
普通表由一个段组成,分区表由多个段组成。
创建表的时候实际上就创建了段,Oracle会给表的段分配一个初始区。
随着数据的插入,初始区被填满,Oracle会再分配一个新区给表的数据段,这个区叫做“递增区”。
如果递增区用完,Oracle还会分配另外的递增区。
1.2.4 段段由一系列的区组成,也是存放数据的逻辑单元。
表由段组成,一个表由一个或多个段组成。
普通表由一个段组成,分区表由多个段组成。
创建表的时候实际上就创建了段,Oracle会给表的段分配一个初始区。
随着数据的插入,初始区被填满,Oracle 会再分配一个新区给表的数据段,这个区叫做“递增区”。
如果递增区用完,Oracle还会分配另外的递增区。
2 内存结构在Oracle中,“数据库”是指物理地存储在磁盘上的数据库文件。
而数据库的启动和运行,是需要一定的内存空间和后台进程的,我们把这些内存空间和后台进程称为Oracle数据库实例(Instance).也就是说一个数据库实例是由一块大的内存空间和一系列的后台进程构成。
对于第一次接触“实例”这个概念的朋友来说,容易把“实例”和“数据库”这两个概念混淆。
实例是“内存”和“后台进程”的总称,“数据库”是数据的物理存储。
一个数据库可以由一个或多个实例驱动,二者之间的关系是一对多的关系。
数据库实例所占用的内存空间分为两部分,一部分叫系统全局区(SGA),另一部分叫程序全局区(PGA)。
2.1 系统全局区(SGA)系统全局区是一组共享的内存结构,这块内存结构用于存放数据和数据库实例的控制信息。
多个用户可以同时连接到同一个实例(Instance),这些用户可以共享该实例的SGA中的数据,因此,系统全局区又叫“共享全局区”。
当启动一个实例时,Oracle 会分配SGA给这个实例,关闭实例时它的SGA又被回收,每个数据库实例都有一个SGA。
SGA主要由以下几部分构成:数据库高速缓冲区(Database Buffer Cache)、重做日志缓冲区(Redo Log Buffer)、共享池(Shared Pool)、Java池(Java Pool) 、大池(Large Pool) 、流池(Streams Pool)。
SGA的每部分结构都是为了满足不同的需求。
(1)数据库高速缓冲区(DataBase Buffer Cache)。
数据库高速缓冲区是SGA的重要组成部分,用于存放从数据文件中读取的数据或者存放用户对数据库所做的修改,所有连接到相同实例的用户都可以共享这些数据。
数据库高速缓冲区中的缓冲器被组织成两个列表:一个是写列表(Write List),一个是最近最少使用列表(Least Recently Used List,LRU)。
最近最少使用列表LRU存放三种缓冲器:自由缓冲器(Free Buffers)、正在被访问的缓冲器(Pinned Buffers)和脏缓冲器(Dirty Buffers )。
写列表存放那些被修改了,但还没有写到磁盘上的脏数据。
当用户查询数据时,Oracle 首先在数据库高速缓冲区(DataBase Buffer Cache)中的正在被访问的缓冲器(Pinned Buffers)中进行查找,如果找到,则把数据返回给用户;如果未找到,Oracle则从数据文件中读取所需数据到自由缓冲器(Free Buffers)中,自由缓冲器就变成了Pinned Buffers,并把该缓冲器排放到最近最少使用列表(LRU)的末尾,然后把Pinned Buffers 中的内容返回给用户。
当用户修改数据库时,直接修改的是Pinned Buffers 中的内容,Pinned Buffers则变成了脏缓冲器(Dirty Buffers)。
当LRU 中不再有自由缓冲器可用时,Oracle会把位于LRU头部(最近最少使用的)的脏缓冲器中的内容(用户的修改)移动到写列表中,而该脏缓冲器又变成了自由缓冲器,LRU中的缓冲器就是这样被周而复始地循环使用的。
写列表中的数据最终要被写入磁盘上的数据文件中。
(2)重做日志缓冲区(Redo Log Buffer)。
重做日志缓冲区是SGA的组成部分,它是一个循环使用的缓冲区,用于存放日志条目,日志条目可实现数据库实例的恢复。
当用户对数据库进行修改(insert,update,delete,create,alter,drop)等操作时,一旦发生断电等意外,用户所做的修改还没有来得及写入数据文件就丢失了。
为了防止这种情况的发生,在数据库运行过程中Oracle会把用户的修改以日志条目的形式记载在SGA的重做日志缓冲区中,并每隔3秒钟或用户提交一个事务时由日志写进程LGWR把日志条目写入磁盘上的联机日志文件。
也就是说Oracle为了以防万一会在数据库运行过程中对还没来得及写入数据文件的用户修改做一物理备份。
当数据库重新启动时,Oracle会从联机日志文件中读取反映用户修改的日志条目,读入日志缓冲区中,再根据日志缓冲区中的日志条目恢复用户先前对SGA中的数据库高速缓冲区所做的修改,最终把用户的修改写入数据文件,从而恢复数据库实例。
初始化参数LOG_BUFFER用于设置日志缓冲区的大小。
比较大的日志缓冲区能够减少联机日志文件的磁盘I/O。
如果一个系统中经常有大的、长时间运行的事务,应该增大LOG_BUFFER 的值。
(3)共享池(Shared Pool)。
共享池也是SGA的重要组成部分,用于存放SQL语句、PL/SQL程序代码、数据字典等信息。
共享池主要包含库缓冲区和数据字典缓冲区。
初始化参数SHARED_POOL_SIZE用于控制共享池的大小。
在默认情况下,32位的平台,SHARED_POOL_SIZE的值是8M,64位的平台,SHARED_POOL_SIZE的值是64M。
库缓冲区存放解析并执行过的SQL语句和PL/SQL程序代码。
当用户发送一条SQL语句或PL/SQL程序代码到数据库时,Oracle首先对这条语句进行语法解析,然后将解析结果(解析树和执行计划)保存到库缓冲区中。
如果不同的用户执行相同的SQL语句,他们可以共享这些解析结果,这会加快SQL语句的执行。
库缓冲区主要包含共享SQL区、私有SQL区、PL/SQL过程和包等。