转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> ORACLE >> 正文
读书总结:Oracle 软件结构         ★★★★

读书总结:Oracle 软件结构

作者:闵涛 文章来源:闵涛的学习笔记 点击数:669 更新时间:2009/4/22 21:58:33


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

实例
.实例的内存结构:SGA(system global areas)和PGA(program global areas)
.实例的进程结构:服务进程和后台进程

内存结构:
SGA(system global areas)
1、数据库缓存 db_cach_size
.keep缓存池 buffer_pool_keep
.recycle缓存池 buffer_pool_recycle
.default缓存池 db_cache_size-(buffer_pool_keey+buffer_pool_recycle)
2、重做日志缓存 log_buffer
3、共享池 shared_pool_size
库缓存:用于缓存已经解析并执行过的SQL和PL/SQL程序代码
.享SQL工作区:存放有SQL语句的语法分析结果和执行计划。如果共享SQL工作区已经没有空闲空间,Oracle将利用LRU算法换出最近很少使用过的SQL语句----->SGA
.有SQL工作区:SQL语句的另一部分被保存到私有SQL工作区中,包括SQL语句中的绑定变量、环境和会话参数等信息,这些信息是属于执行该语句的用户所私有的,其他用户即使执行相同的SQL语句也不能使用这些信息。只有在共享服务器(servers=shared)时,私有SQL工作区才会在SGA中创建。一般情况下私有SQL工作区位于PGA中。
#库缓存的大小与open_cursors密切相关。open_cursors参数用于指定数据库中能够同时打开的游标数量,每条查询语句都需要一个游标。
数据库字典缓存:这是一种“行缓存”,即在其中保存的是一条条的记录,而不像其他缓存那样保存的是缓存块。
4、Java池
5、大型池 large_pool_size
.进行数据库备份和恢复操作
.执行具有大量排序操作的SQL语句
.招待并行化的数据库操作
#如果没有在SGA区中创建大型池,上述操作所需的缓存空间将在共享池或PGA中分配。

PGA(program global areas)
保存服务进程的数据和控制信息的内存结构,这个内存结构是非共享的,只有服务进程本身才能够访问它自已的PGA区。每个服务进程都有它自已的PGA区,各个服务进程PGA的总和即为实例的PGA区的大小。
1、私有SQL工作区
在执行比较复杂的查询时(比如决策支持系统中的查询语句),经常会需要在PGA中创建一个比较大的动态缓存区,用来专门执行如下一些必须在内存中进行的操作:
.排序(order by,group by)
sort_area_size
sort_area_retained_size
.连接(inner join )
hash_area_size
.集合运算(union,interset,minus)
create_bitmap_area_size

#servers=dedicated
私有SQL工作区将保存在服务进程的PGA中
#servers=shared
私有SQL工作区的一部分将保存在SGA区中

2、会话内存区
用于保存用户会话的变量(登录信息)以及其他与会话相关的信息
#servers=dedicated
会话内存区将保存在为这个会话提供服务的专用服务进程的PGA中。这时只有这个服务进程需要使用该会话的会话信息。
#servers=shared
会话内存区将位于SGA区中而不是PGA区中,因为会话信息被所有的共享服务进程使用。

workarea_size_policy=auto
pga_aggregate_target=XXX

进程结构

服务进程:
1、专用服务进程:一个专用服务进程只能为一个用户提供服务
2、共享服务进程:一个共享服务进程可以为多个用户提供服务
.解析并执行用户所提交的SQL语句。
.在SGA区的数据库缓存中搜索用户进程所访问的数据,如果数据不在缓存中,则需要从硬盘数据文件中读取所需的数据,而将它们复制到缓存中。
.将数据返回给用户进程。

后台进程
DBWn
db_writer_processes
.当用户执行insert或update等操作时,会首先将插入的数据写入数据库缓存。在这个过程中,如果Oracle在数据库缓存的LRU列表中搜索了一定数据(db_block_max_scan)的缓存块后,仍然没有找到可用的空闲缓存块,DBWR进程将启动,由DBWR进程将脏缓存块写入数据文件之后,数据库缓存将获得更多的空闲缓存块。
.当检查点发生时,将启动DWBR进程
.当数据库缓存LRU列表的长度达到db_block_write_batch指定值的一半时,DBWR进程将启动。
.若发生超时(大约3秒内未被启动),DBWR进程被启动。
LGWR
.用户通过commit语句提交当前事务
.重做日志缓存写满三分之一
.DBWR进程开始将脏缓存块写入数据文件
.若发生超时(大约3秒),此时会启动LGWR
CKPT
log_checkpoint_timeout
log_checkpoint_interval
log_checkpoint_to_alert

SMON
PMON
ARCn
archive_log_start

RECO
Dnnn



[系统软件]EXP-00008: ORACLE error 904 encountered的解决方…  [常用软件]PB7 连接 Oracle 的配置方法
[Web开发]oracle Export and Import 简介  [Web开发]ADO访问Oracle结果集的心得
[JAVA开发]JDBC+Hibernate将Blob数据写入Oracle  [JAVA开发]J2EE应用中与Oracle数据库的连接
[JAVA开发]Oracle Application Serve_  [其他]HP-UXrx2600B.11.22Uia64安装oracle9i9.2foria64手…
[其他]在RedhatEnterpriseserver3上安装oracle9iR2的注意…  [其他]PROC++批量导入导出ORACLE数据库表
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台