oracle体系结构

合集下载

《ORACLE体系结构》PPT课件

《ORACLE体系结构》PPT课件

– 将表空间设置为脱机或 只读
– 删除或截断表
– 备份表空间
整理ppt
24
LOG Writer(LGWR)
LGWR在以下情况将缓 冲区中的数据写入磁盘:
– 事务提交 – 三分之一的redo日志缓
冲区已满
– Redo日志缓冲区中的内 容超过1M
– 每三秒钟 – 在DBWn写磁盘之前
整理ppt
25
System Monitor(SMON)
Redo Log Buffer Cache缓存对于数据块 的所有修改。
– 主要用于恢复 – 其中的每一项修改记录都被称为redo 条目。 – 利用Redo条目的信息可以重做修改。
整理ppt
15
Large Pool
Large Pool是SGA中一个可选的内存区域, 它只用于shared server环境。
information
SGA
Shared Server
Stack space
sort area, cursor information
SGA Session information
Shared SQL整A理repapt
Shared SQL Area
18
Program Global Area(PGA)
– ALTER SYSTEM SET SHARED_POOL_SIZE = 64M;
整理ppt
11
Library Cache
Libray Cache缓存最近被执行的SQL和 PL/SQL的相关信息。
– 实现常用语句的共享 – 使用LRU算法进行管理 – 由以下两个结构构成:
• Shared SQL area • Shared PL/SQL area

描述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 体系结构详解一、体系结构图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体系结构简介一、数据库(Database)数据库是一个数据的集合,不仅是指物理上的数据,也指物理、存储及进程对象的一个组合。

Oracle是关系型数据库治理系统(RDBMS)。

二、实例(Instance)数据库实例(也称为服务器Server)就是用来访问一个数据库文件集的一个存储结构及后台进程的集合。

它使一个单独的数据库可以被多个实例访问(也就是ORACLE并行服务器-- OPS)。

实例和数据库的关系如下决定实例的组成及大小的参数存储在init.ora文件中。

三、部结构表、列、数据类型(T able、Column、Datatype)Oracle中是以表的形式存储数据的,它包含若干个列;列是表的属性的描述;列由数据类型和长度组成;Oracle中定义的数据类型主要有CHAR、VARCHAR2、NUMBER、DATE、LONG、LOB、BFILE等,具体的数据类型情况将在本栏目的相关文档中具体介绍。

约束条件(Constraint)表中以及表间可以存在一些数据上的逻辑关系、限制,也就是约束。

Oracle中的约束主要有主键(PK)、外键(FK)、检查(CHECK)、唯一性(UNIQUE)等几种;拥有约束的表中每条数据均必须符合约束条件。

抽象数据类型(Abstract Datatype)可以利用CREATE TYPE命令创建自定义的抽象数据类型。

分区(Partition)可以利用分区将大表分隔成若干个小的存储单元,逻辑上仍然是一个完整的独立单一实体,以减小访问时数据的查找量,提高访问、存储效率用户(User)用户不是一个物理结构,但是它与数据库的对象拥有非常重要的关系--用户拥有数据库对象,以及对象的使用权。

模式(Schema)用户拥有的对象集合称为模式。

索引(Index)数据库中每行记录的物理位置并不重要,Oracle为每条记录用一个ROWID来标识,ROWID记录了记录的准确位置。

索引是供用户快速查找到记录的数据库结构。

oracle 体系结构

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数据库体系结构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数据库的最大逻辑划分区域,通常用来存放数据表、索引、回滚段等数据对象。

第2讲_Oracle的体系结构

第2讲_Oracle的体系结构

Page 9
2.2.3 控制文件(.ctl)
控制文件(control files)是一个较小的二进制文件,在Oracle服务器在启 动期间用来标识物理文件和数据库物理结构。 创建数据库时,创建控制文件。数据库的启动和正常运行都离不开控制文 件。启动数据库时,Oracle从初始化参数文件中获得控制文件的名字及位 置,打开控制文件,然后从控制文件中读取数据文件和联机日志文件的信 息,最后打开数据库。数据库运行时,Oracle会修改控制文件。 三个控制文件内容一样,镜像关系。
– 将执行结果返回用户
2.5.3 后台进程
为所有数据库用户异步完成各种任务
Page 21
服务器进程
后台进程
用户进程
Page 22
2.5.3.1 DBWR进程
数据库写进程。该进程执行将缓冲区写入数据文件,是负责缓冲存储区管 理的一个ORACLE后台进程。 当缓冲区中的一缓冲区被修改,它被标志为“弄脏”,DBWR的主要任务是 将“弄脏”的缓冲区写入磁盘,使缓冲区保持“干净”。
实例
用户进程 共享缓冲区 库缓冲区 服务器进程 PGA 数据字典
SGA
数据缓冲区 日志缓冲区 大池
Java池
PMON SMON DBWR LGWR CKPT Others
参数文件 口令文件
数据文件
控制文件
重做日 志文件
归档日志文件
数据库
Page 3
数据库和实例
数据库(Database)及实例(Instance) 数据库:物理操作系统文件或磁盘(disk)的集合。 实例:数据库启动时,系统首先在服务器内存中分配系统全局区 (SGA),构成了Oracle的内存结构,然后启动若干个常驻内存 的操作系统进程,即组成了Oracle的进程结构,内存区域和后台 进程合称为一个Oracle实例。

简述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数据库体系结构
(1)PFILE
在Oracle 9i之前,初始化参数都是以文本格式存放 的。在Windows平台上,建议将PFILE文件存放在 %ORACEL_HOME%\database目录中,文件名为 initSID.ora,其中SID为实例名。
(2)SPFILE
SPFILE是以二进制格式存放的。在Window 平台上,Oracle建议将SPFILE存放在 %ORACLE_HOME%\dbs 目录中。文件名为sp。
2.4.2 段
• 段是用户建立的数据库对象(如:表,索引, 簇等)的存储表示。它是有一个或多个区组 成的。
• 当建立表、索引、簇时,Oracle会为这些对 象分配段,以存放它们的数据信息,并且段 名与对象名完全相同。
• 用户建立的每一个表都会有一个在表空间中 存储的逻辑段。为用户所建立的对象生成的 段都要在磁盘上占用空间。
• 日志文件主要用于数据库恢复。
• 查看重做日志文件
SQL> select member from v$logfile;
MEMBER -------------------------------------------------E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO02.LOG E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO01.LOG
db_block_size 指定标准oracle块的尺寸
db_cache_size 指定标准数据高速缓存的尺寸
share_pool_size 指定共享池的尺寸
常用初始化参数(一)
参数名 log_buffer sga_max_size java_pool_size large_pool_size

Oracle体系结构(共79张PPT)

Oracle体系结构(共79张PPT)

32
日期
第32页,共79页。
分析
在执行COMMIT操作时,后台进程LGWR要 开始工作,所以事务变化被记载到重做日志 中。因为只有在发出检查点时,才会将SCN 值写入控制文件和数据文件头部,所以控制 文件和数据文件的SCN值保持一致,并且存 放的是先前检查点的SCN值。
控制文件和数据文件的SCN值一致,与重做 日志不一致!
28
日期
第28页,共79页。
CKPT工作原理
当Oracle发出检查点时,系统会将检查点时刻的
SCN值写入到控制文件和数据文件头部,同时还会促
使DBWR进程将所有脏缓冲区写入到数据文件中。
29
日期
第29页,共79页。
检查点工作机制
在DBWR进程工作之前,LGWR进程首 先将重做日志缓冲区内容写入到重做日志文 件,即该时刻的SCN值会被写入重做日志。
Oracle使用的主要内存结构包括系统全局 区SGA和程序全局区PGA。
9
日期
第9页,共79页。
SGA区
日期
10 第10页,共79页。
数据高速缓存
保存最近从数据文件中读取的数据块。分为 脏缓存块、空闲缓存块和命中缓存块三类。
脏缓冲块:当执行INSERT、UPDATE以及 DELETE操作时,服务器进程修改数据高速 缓存的相应数据,此时缓冲区的内容与数据 文件中的内容不一致。
当CKPT进程工作的时候,会将当前时 刻的SCN值写入数据文件和控制文件。
在发出检查点时刻,数据文件、控制文 件和重做日志的SCN值完全一致。
30
日期
第30页,共79页。
系统恢复
当运行Oracle Server时,在访问数据 文件、控制文件和重做日志时,Oracle会定 期检查并比较每种文件的SCN值,确定文件 是否损坏、系统是否出现异常,最终确定系 统是否需要进行恢复。

Oracle体系结构

Oracle体系结构
数据字典
3.数据字典的作用 获取有关用户、模式对象和存储结构的信息,从而 控制和管理服务器工作。 任何数据库用户都可从DD中读取关于数据库的信 息,从而实现对数据库进行相关的开发、修改和维 护等操作。 DBA可以从数据字典中获取数据库的各种参数信息 和运行状态信息,从而进行有效的数据库管理。
3.1 Oracle服务器体系结构概述

数据字典
(3)"DBA_"为前缀的用户视图则包含所有数据库对象的 信息,而不管其所有者是谁,这类视图只能被具有DBA权限 的用户或被授予了SELECT ANY TABLE 权限的用户使用。
4.用户视图
如:以用户SCOTT登录Oracle服务器,执行下述语句:
3.1 Oracle服务器体系结构概述
Oracle 服务器
Oracle服务器由Oracle数据库和 Oracle实例组成 。 Oracle数据库是指Oracle保存数据的 一系列物理结构和逻辑结构,主要由一 系列操作系统文件组成。 Oracle实例就是在运行状态下的 Oracle软件,主要是由操作系统的内存 结构和一些进程组成。
3.1 Oracle服务器体系结构概述

数据字典
4.用户视图 (2)"ALL_"为前缀的用户视图通常包含包括执行查询 的用户所拥有的对象信息及授权给该用户所拥有的对象 信息,这类视图可以被一般用户使用。
例如,用户SCOTT想知道自己能够访问那些表。 SQL>SELECT TABLE_NAME, TABLESPACE_NAME FROM ALL_TABLES; 结果将会显示用户SCOTT所能访问的全部表的表名和表空间情况。 TABLE_NAME TABLESPACE_NAME ---------------------------------------- ------------------------------------DUAL SYSTEM SYSTEM_PRIVILEGE_MAP SYSTEM TABLE_PRIVILEGE_MAP SYSTEM STMT_AUDIT_OPTION_MAP SYSTEM …………

Oracle数据库体系结构小结

Oracle数据库体系结构小结

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数据库的最外层。

二、物理层Oracle数据库的物理层包括数据文件、控制文件和重做日志文件。

其中,数据文件用于存储数据表、索引和其他对象的数据;控制文件则记录了数据库的结构信息和操作日志,是维护数据库一致性和恢复数据的关键元素;重做日志文件用于记录正在进行的操作和已经完成的操作,以便在系统崩溃或停机时进行恢复。

三、逻辑层Oracle数据库的逻辑层包括多个服务组件,如SQL解析器、优化器、缓存池、锁管理器、存储管理器等。

其中,SQL解析器用于解析SQL语句,将其转换成可执行的优化器,并进行语法和语义检查;优化器则负责分析并优化SQL执行计划,以提高查询效率;缓存池用于存储查询结果和表空间等数据对象,提高查询响应速度;锁管理器则负责管理并发访问,防止数据冲突,保证数据库的一致性和稳定性。

四、视图层Oracle数据库的视图层提供了多种视图和接口,包括SQL*Plus、SQL Developer、Toad等。

其中,SQL*Plus是Oracle自带的命令行工具,提供简单的SQL语句执行和结果输出;SQL Developer是Oracle 提供的图形化界面工具,提供更为便捷的数据库管理和开发支持;Toad则是第三方软件,提供了更为强大和灵活的数据库管理和开发支持。

五、总结Oracle数据库作为目前世界领先的企业级关系数据库管理系统,其体系结构设计合理,层次清晰,提供了完备的物理、逻辑和视图三层管理机制,为企业级应用系统提供了高效、可靠、稳定的运行环境和数据服务。

oracle体系结构简介

oracle体系结构简介

oracle体系结构简介一、物理存储结构1、数据文件存放数据库数据,以dbf为扩展名。

将数据放在多个数据文件中,再将数据文件分放在不同的硬盘中,可以提高存取速度。

数据文件由数据块构成,块大小由数据库创建时确定。

2、重做日志文件,以rdo为扩展名。

含对数据库所做的更改记录,这样万一出现故障可以启用数据恢复。

一个数据库至少需要两个重做日志文件。

重做日志在日志文件中以循环的方式工作。

有归档日志模式和非归档日志模式。

3、控制文件,以ctl或ctrl为扩展名。

控制文件维护数据库的全局物理结构,记录数据库中所有文件的控制信息,每个数据库至少要有一个控制文件,建议用户使用两个或更多控制文件,并存放在不同的磁盘上。

Oracle系统通过控制文件保持数据库的完整性,以及决定恢复数据时使用哪些重做日志。

4、参数文件,以ora为扩展名。

在一个数据库启动时,每个参数都有一个默认值,而参数文件中的设置值被用来更改默认值,参数值极大影响了oracle如何去执行其不同的任务。

参数文件包括以下几种:<1>、初始化参数文件。

当创建一个数据库时,oracle创建了一个默认的init.ora文件,如果不修改任何参数,oracle将用所有的缺省值来启动数据库,通常根据实际的应用修改参数设置以提高性能。

<2>、配置参数文件。

一般被命名为config.ora,它被用于特定实例的信息。

这个文件是一个由init.ora文件调用或激活的文本文件,init.ora中包含一个ifile参数以设置config.ora文件的位置。

既然一个数据库可以有一个或多个实例与之关联,那么配置文件中每一个参数对于不同的实例配置可能不同,当然,如果和数据库关联的实例只有一个,所有信息都保存在文件init.ora中,那么config.ora文件就不是必需的了。

<3>、服务器参数文件(spfile)。

它被设计为一个服务器端的参数文件,可以被认为是在oracle数据库服务器执行的机器上被管理的初始化参数的仓库。

Oracle数据库体系结构(详细版)

Oracle数据库体系结构(详细版)

Oracle体系结构Oracle核心竞争力可扩充性:Oracle系统有能力承担增长的工作符合,并且相应的扩充系统资源利用情况。

可靠性:无论出现系统资源崩溃,电源断电还是系统故障的时候,我们都可以对Oracle进行配置。

以保证检索用户数据事务处理的时候,不受到影响。

可管理性:数据库管理员可以微调Oracle使用内存的方式,以及Oracle向磁盘写入数据的频率。

并且管理可以调整,数据库为连接到数据库的用户分配操作系统进程的方式。

Oracle总体结构分为三个部分第一部分:系统全局区(SGA)第二部分:程序全局区和后台进程第三部分:Oracle的文件如果从功能上划分的话:存储结构:由这些文件就构成了Oracle的物理存储结构。

内存结构:使用内存最多的是SGA,也是影响数据库系统性能最大的一个参数。

进程结构:前台进程服务进程和用户进程,是根据实际需要而运行的,并在需要结束后立刻结束。

后台进程是指Oracle数据库启动后自动启动的几个操作系统进程。

存储结构包括物理结构和逻辑结构,既独立又相互联系的。

物理结构:是和操作系统平台有关的。

逻辑结构:逻辑存储结构是和操作系统平台无关的。

_______________________________________________________________________________这个图是两种存储结构中的对应关系表空间包括系统表空间和用户表空间。

表空间也是最大的逻辑单位。

块是最小的一个逻辑单位。

逻辑结构的表空间对应着物理结构的数据文件,也就是创建表空间的时候要给它指定数据文件,但是一个表空间可以对应多个数据文件。

表空间的大小也就是他包含的数据文件大小的总和。

数据文件呢同时又对应着操作系统中的数据块,数据文件也是以数据块的形式,存在于操作系统中。

逻辑结构中的块也对应着操作系统的数据块。

——————————————————————————————————————— 物理存储结构Oracle的物理存储结构,也就是Oracle的数据库文件数据库文件又分为主要文件和其他文件主要文件:首先来看数据文件:就是物理存储Oracle数据库数据的文件有一下特点:◆每一个数据文件,只与一个数据库相关联。

Oracle体系结构详解

Oracle体系结构详解

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的体系结构
注意:
•临时表空间所对应的临时数据文件是一类比较特殊的数据文件。 •临时文件的信息只能通过数据字典视图DBA_TEMP_FILE和动 态性能视图V$TEMPFILE来查看;不能像普通数据文件一样通过 DBA_DATA_FILES和V$DATAFILE视图来查看。
3.物理存储结构
3.2控制文件
数据库控制文件是一个很小的二进制文件,在其中包含了关 于数据库物理结构的重要信息。通过在加载数据库时读取控 制文件,Oracle才能找到自己所需的操作系统文件(数据文 件、重做日志文件等)。
当一个段中的所有空间被使用完后,系统将自动 为该段分配一个新的盘区。
2.逻辑存储结构
2.3段
段是由一系列盘区组成,它也不再是存储空间的 分配单位,而是一个独立的逻辑存储结构。
对于具有独立存储结构的对象,它的数据全部存 储在保存它的段中。一个段只属于一个特定的数 据库对象,每当创建一个具有独立段的数据库对 象时,Oracle将为它创建一个段。
5.实例的进程结构
5.1用户进程
用户执行一个Oracle应用程序或启动一个Oracle工具(如 SQL*Plus)时,创建一个用户进程来执行相应的用户任务。 相关概念:
(1)连接:是一个用户进程与数据库实例之间的一条通信路径, 这条通信路径通过操作系统平台中的进程间通信机制或网络连接来 实现。
3.物理存储结构
3.3重做日志文件
重做日志文件是记录数据库中所有修改信息的文件
1.修改前的数据 2.修改后的数据 当满足一定条件时先将修改操作所产生的重做记录写入重做日志文件 中,然后才将内存中的修改结果成批的写入数据文件,最后再提交事 务。 重做日志文件是由重做记录组成的,重做记录是由修改向量组成的。 当用户执行一条update语句对某一个表中的记录进行修改时,会生成 一条记录。这条记录用多个向量记录下了被这条语句修改过的各个数 据块中的信息。

Oracle体系结构

Oracle体系结构

Oracle体系结构一、物理结构二、逻辑结构三、内存结构四、数据库实例与进程五、数据字典一、Oracle 的物理结构Oracle 数据库文件包括数据文件、日志文件、控制文件、配置文件数据文件(1)用来存储数据库中的全部数据,如数据库表中的数据和索引数据。

通常为后缀名为.dbf格式的文件。

(2) 每个Oracle 可以有一个或多个数据文件,一个数据文件只能属于一个数据库。

(3) 每个数据文件又由若干物理块组成;(4) 一个或多个数据文件组成表空间;日志文件(重做日志文件)(1)用于记录数据库所做的全部变更(如增加、删除、修改),以便在系统发生故障时,用它对数据库进行恢复。

名字通常为Log*.dbf格式。

控制文件(1)用于打开和存取数据库。

(2)是较小的二进制文件,记录了数据库的物理结构,如:数据库名、数据库的数据文件和日志文件的名字和位置等信息。

(3)名字通常为Ctr*.ctl格式,如CtrlCIMS.ctl。

(4)控制文件中的内容只能够由Oracle本身来修改。

(5)每个数据库必须至少拥有一个控制文件。

一个数据库也可有多个控制文件,但是一个控制文件只能属于一个数据库。

配置文件:(1)是一个ASCII文本文件,记录Oracle 数据库运行时的一些重要参数。

(2)名字通常为initsid*.ora格式,如:initCIMS.ora,(3)SID相当于它所控制的数据库的标识符。

(4)每个Oracle数据库和实例都有它自己惟一的init.ora 文件。

二、Oracle 的逻辑结构逻辑结构描述了数据库从逻辑上如何来存储数据块中的数据。

包括表空间、段、区、数据块和模式对象。

逻辑结构支配一个数据库如何使用系统的物理空间,模式对象及其之间的关系则描述关系数据库之间的设计。

一个数据块从逻辑上是由一个或多个表空间组成,表空间是数据块中物理编组的数据仓库,每个表空间由段构成,段由一组区组成,一个区由连续的数据块组成。

Oracle体系结构

Oracle体系结构

Oracle体系结构:Oracle有自己的文件结构、缓冲区结构、进程结构以及自身的优化功能。

Oracle服务器主要有两部分组成:Oracle数据库和Oracle实例。

也就是说我们的Oracle 数据库只是一个数据文件和相关数据库管理系统的集合,真正为用户提供服务的是Oracle 实例。

Oracle实例的内存结构组织主要包含在系统全局区(SGA:System Global Area)的内存区域中,SGA可以被所有用户进程共享。

·Oracle服务器的内存结构:Oracle服务器有两种内存结构:系统全局区(SGA)和程序全局区(PGA)系统全局区是一组共享内存结构,存放一个Oracle数据库实例的控制信息和各个共享用户的数据。

程序全局区是用户进程连接到数据库并创建会话时,有Oracle服务器进程进行分配的、专门用于当前用户会话的内存区,存储该用户连接期间与SQL语句执行相关的信息,该区域是私有的。

·Oracle服务器的进程结构:Oracle数据库系统中的进程只要分为:用户进程和服务器端进程,服务器端进程又分为服务器进程和后台进程。

用户进程在客户端工作,它向服务器进程发出请求信息。

SQL*Plus、Oracle Forms Builder 等都是用户进程。

服务器进程接收用户发出的请求,并根据请求与数据库通信(通过SGA),通过这些通信完成用户进程对数据库中数据的处理请求,而具体的数据读写、日志写入等操作则是由后台进程完成。

服务器端后台进程:包括数据库写入进程(DBWn),日志写入进程(LGWR),日志归档进程(ARCn),检查点进程(CKPT),系统监控进程(SMON)和进程监控进程(PMON)等。

1,数据库写入进程(DataBase Writer,DBWn):作用是将已经更改的数据块从内存写入到实际的数据文件。

默认情况下在数据库实例启动时只启动了一个数据库写入进程,即DBW0,通过设置初始化参数DB_WRITER_PROCESSES可以最多定义20个(编号分别是0-9和a-j)数据库写入进程来执行写入操作。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
相关文档
最新文档