【2007】知识是需要沉淀的; 思想是在不断学习,磨练中成熟的; 技术是在创新中开拓的…………… 【2007】不经历风雨,怎能见彩虹,没有人能随随便便成功。加油!

Oracle架构的基础知识

上一篇 / 下一篇  2010-03-03 23:30:28 / 个人分类:Oracle

1、物理结构(由控制文件、数据文件、重做日志文件、参数文件、归档文件、口令文件组成)

d6Eo.d5cR0

 51Testing软件测试网 Ng |p/yX)}.X1\

一个数据库中的数据存储在磁盘上物理文件,被使用时,调入内存。

i wr:o*NQ p9fB0

其中控制文件、数据文件、重做日志文件、跟踪文件及警告日志(trace files,alert files)属于数据库文件;

)E([s6v.MX*H#O#V/m0

参数文件(parameter file)口令文件(password file)是非数据库文件51Testing软件测试网*h p6Zz] r

 

{6o_4X+nV:b0

1.1数据文件:存储数据的文件.数据文件典型地代表了根据他们使用的磁盘空间和数量所决定的一个Oracle数据库的容积。51Testing软件测试网{u#ubKR8l

由于性能原因,每一种类型的数据放在相应的一个或一系列文件中,将这些文件放在不同的磁盘中。51Testing软件测试网tk4Z \8~ R

types:

;sZ/`5N;wr(S/{0

.data dictionary .data51Testing软件测试网7L^^4ADFx

.redo data .index51Testing软件测试网L;|q'W q*hy

.temporary data等等

9{ L2fd|;H;_b U0

1.2控制文件:包含维护和验证数据库完整性的必要信息、例如,控制文件用于识别数据文件和重做日志文件,一个数据库至少需要一个控制文件.

7Z I]3iC0~N'wF0

 

w7I8t_&_0

控制文件内容

vP J.edl ?A0

。数据库名

0S%^1\SR:C4~[0

。表空间信息

Q(tVr.h)g Mj0

。所有数据文件的名字和位置51Testing软件测试网ND-vF)yjF

。所有redo日志文件的名字和位置51Testing软件测试网$d4y(r z k^Rt

。当前的日志序列号51Testing软件测试网5_3n {[1a DJ6C

。检查点信息

z&dL/n2WHr$\-P2k0

。关于redo日志和归档的当前状态信息

5k w,D^T4a0

 51Testing软件测试网Yn(R4L;b

控制文件的使用过程51Testing软件测试网^] i})N2Yl!c

控制文件把Oracle引导到数据库文件的其它部分。启动一个实例时,Oracle从参数文件中读取控制文件的名字和位置。安装数据库时,Oracle打开控制文件。最终打开数据库时,Oracle从控制文件中读取数据文件的列表并打开其中的每个文件。

3gM} ]5e0

 51Testing软件测试网RMOT}

 

,RY4Gx,\'YeSPR0

1.3重做日志文件:含对数据库所做的更改记录,这样万一出现故障可以启用数据恢复。一个数据库至少需要两个重做日志文件.51Testing软件测试网7fg*G@2bt.S

1.4跟踪文件及警告日志(Trace Files and Alert Files)51Testing软件测试网Zz!`:Ugf8W

instance中运行的每一个后台进程都有一个跟踪文件(trace file)与之相连。Trace file记载后台进程所遇到的重大事件的信息。51Testing软件测试网x3m6a%p0Tt0oH

 51Testing软件测试网4sG"iDD;ON_2Q

警告日志(Alert Log)是一种特殊的跟踪文件,每个数据库都有一个跟踪文件,同步记载数据库的消息和错误.51Testing软件测试网Qt%w!fNQX F

 51Testing软件测试网,x o+Giv-z/UX

1.5参数文件:包括大量影响Oracle数据库实例功能的设定,如以下设定:

Z'gXb:p1rv]2qH0

。数据库控制文件的定位51Testing软件测试网 V'EA%I&c*Fi7GZ

Oracle用来缓存从磁盘上读取的数据的内存数量

#I6jy"me8]'B(M0

。默认的优化程序的选择.51Testing软件测试网pY)ei"xO.H%Y%`g

 

Pg4K4ssaQO0

和数据库文件相关,执行两个重要的功能

(f2mI*m2`|it0

1〉为数据库指出控制文件

N {mDi g l0

2〉为数据库指出归档日志的目标51Testing软件测试网xyA {"?6M"c9_

 

r1]sv9}j0

 

6M h A,Q"`0P%B;O0

1.6归档文件:是重做日志文件的脱机副本,这些副本可能对于从介质失败中进行恢复很必要。51Testing软件测试网QLH,y0`'C

 51Testing软件测试网e tA1u:Gk T E

1.7口令文件:认证哪些用户有权限启动和关闭Oracle例程.

*lS&J Q0Dw2G(U0

 

/f2oe+]d;`:vj w k0

 

1t[7|YH9g4R0

2、逻辑结构(表空间、段、区、块)

@!Ps)Z"w*Y0

 51Testing软件测试网aBX^q;u

表空间:是数据库中的基本逻辑结构,一系列数据文件的集合。51Testing软件测试网U!G C%pl8^q4N

段:是对象在数据库中占用的空间.51Testing软件测试网xC'G b3yn

区:是为数据一次性预留的一个较大的存储空间.

0V*QBQ L%j6~0

块:ORACLE最基本的存储单位,在建立数据库的时候指定.51Testing软件测试网{o.Qy&b#h

 

[9c{? w-G\;s7[?!I:Q0

 51Testing软件测试网M7H;T V7O.]

3、内存分配(SGAPGA

*_"u w B rZIPTE0

 

xt$H#m;Nl0

SGA:是用于存储数据库信息的内存区,该信息为数据库进程所共享。它包含Oracle服务器的数据和控制信息,它是在Oracle服务器所驻留的计算机的实际内存中得以分配,如果实际内存不够再往虚拟内存中写。

ks+i&S1X*R~7`Y0

 

t`#al o-w*Z-rJ0

PGA:包含单个服务器进程或单个后台进程的数据和控制信息,与几个进程共享的SGA正相反,PGA是只被一个进程使用的区域,PGA在创建进程时分配,在终止进程时回收.51Testing软件测试网E0z!W(R { V$N

 

R \ k8],rz?H3v j0

4、后台进程

lRG/Q3z\m2I)]0

包括数据写进程(Database Writer,DBWR)、日志写进程(Log Writer,LGWR)、系统监控(System Monitor,SMON)、进程监控(Process Monitor,PMON)、检查点进程(Checkpoint Process,CKPT)、归档进程、服务进程、用户进程)51Testing软件测试网E Em/qb'y O\

 

5B#i ejLEHK2l0

数据写进程:负责将更改的数据从数据库缓冲区高速缓存写入数据文件

|)a)x%g Wm0

日志写进程:将重做日志缓冲区中的更改写入在线重做日志文件51Testing软件测试网m bw vaS

系统监控:检查数据库的一致性如有必要还会在数据库打开时启动数据库的恢复

.e-S,j8f7l0

进程监控:负责在一个Oracle进程失败时清理资源51Testing软件测试网5Id-wn0U\

检查点进程:负责在每当缓冲区高速缓存中的更改永久地记录在数据库中时,更新控制文件和数据文件中的数据库状态信息。该进程在检查点出现时,对全部数据文件的标题进行修改,指示该检查点。在通常的情况下,该任务由LGWR执行。然而,如果检查点明显地降低系统性能时,可使CKPT进程运行,将原来由LGWR进程执行的检查点的工作分离出来,

3a;DaBq3Erb0

CKPT进程实现。对于许多应用情况,CKPT进程是不必要的。只有当数据库有许多数据文件,LGWR在检查点时明显地降低性能才使CKPT运行。CKPT进程不将块写入磁盘,该工作是由DBWR完成的。init.ora文件中CHECKPOINT_PROCESS参数控制CKPT进程的使能或使不能。缺省时为FALSE,即为使不能。51Testing软件测试网0{!@uA,R9N

 51Testing软件测试网F \ z!O!NV

归档进程:在每次日志切换时把已满的日志组进行备份或归档

@9q d6pU0

服务进程:用户进程服务。

)`'V.T E&RF[4N0

用户进程:在客户端,负责将用户的SQL语句传递给服务进程,并从服务器段拿回查询数据。

y?$NX"A9R0

 51Testing软件测试网-o#n2F'U7?U4Uf2`AHf

 

&n~&Q9]/s0

5SCN(System ChangeNumber):系统改变号,一个由系统内部维护的序列号。当系统需要更新的时候自动增加,他是系统中维持数据的一致性和顺序恢复的重要标志。

cXt'U5n g r#Hs_0

 

7o2njOO0

oracle架构的基础知识(入门级)51Testing软件测试网Nk(f(t'M/h*SUu~

 

t-\"h6nq/x)kL;cq0

TAG:

 

评分:0

我来说两句

Open Toolbar