ORACLE内存结构SGA区域信息.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle内存结构:SGA的区域信息 ChinaITLab收集整理 2005-12-23 保存本文 推荐给好友 QQ上看本站 收藏本站   SGA的区域信息   SGA(system global area)系统全局区跟一些必须的后台进程合进来称为实例(Instance)。说它是全局区是包含了全局变量和数据结构,是系统区是包含了进入整个Oracle Instance的数据结构而不是特定的进程结构。   SGA区域:   SGA大概包括下面四到五种区域:   The fixed area   The variable area   The database blocks area   The log buffer   The instance lock database(for parallel server instances)——OPSRAC   根据内存的大小,我们可以把The fixed area和The log buffer设为很小。   The fixed area:   SGA中的The fixed area包含了数千个原子变量,以及如latches和指向SGA中其它区域的pointers(指针)等小的数据结构。通过对fixed table内表X$KSMFSV查询(如下)可以获得这些变量的名字,变量类型,大小和在内存中的地址。   SQL select ksmfsnam, ksmfstyp, ksmfssiz, ksmfsadr   2 from x$ksmfsv;   这些SGA变量的名字是隐藏的而且几乎完全不需要去知道。但是我们可以通过结合fixed table内表X$KSMMEM获得这些变量的值或者检查它们所指向的数据结构。   SQLselect a.ksmmmval from x$ksmmem a where addr=(select addr from x$ksmfsv where ksmfsnam=‘kcrfal_’);   SGA中的fixed area的每个组成部分的大小是固定的。也就是说它们是不依靠于其它的初始化参数的设置来进行调整的。fixed area中的所以组成部分的大小相加就是fixed area的大小。   The variable area:   SGA中的the variable area是由large pool和shared pool组成的。large pool的内存大小是动态分配的,而shared pool的内存大小即包含了动态管理的内存又包含了永久性的(已经分配的)内存。实际上,初始化参数shared_pool_size的大小设置是指定shared pool中动态分配的那部分内存的一个大概的SIZES而不是整个shared pool的SIZES   Shared pool中永久性的内存包含各种数据结构如:the buffer headers, processes, sessions, transaction arrays, the enqueue resources , locks, the online rollback segment arrays, various arrays for recording statistics.其中大部分的SIZE是依靠初始参数的设置来确定的。这些初始参数只能在实例被关闭的状态下才能够进行修改。所以这里说的永久性是针对实例打开状态下的生存期而言。简单的一个例子PROCESSES参数。在这个process arrays中的slots用完之后,如果有其它的process想再申请一个process则会失败,因为它们在内存中的大小是在实例启动时预分配的。不能动态修改之。   针对很多永久性的arrays,有很多的X$表都把这些元素做一个记录而成员结构则作为字段。V$视图的数据就是从这些X$表获得。如V$PROCESS是基于X$KSUPR内表的。V$PROCESS视图不包含X$KSUPR的全部字段。 X$KSUPR也没有覆盖SGA进程结构的所有成员。   The variable area的在SGA中的SIZES就等于LARGE_POOL_SIZE,SHARED_POOL_SIZE和永久性的内存arrays的SIZE三者相加。 永久性的内存arrays的总的SIZE可以通过初始参数的设置来计算得到。然而,你需要知道从参数获得这些array sizes的方程式,每个array元素大小的字节数,还有array头信息的sizes.这些跟Oracle的版本号和OS有关。实际使用中,我们是不必要计算这个永久性的内存arrays的SIZE的。如果想知道,一个方法就是在STARTUP NOMOUNT数据库时记下the variable a

文档评论(0)

gangshou + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档