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)----ops&rac
根据内存的大小,我们可以把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获得这些变量的值或者检查它们所指向的数据结构.
sql>select 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 area.然后减去参数中large_pool_size和shared_pool_size的大小就可以.
the database block area:
这个区域是数据库块的拷贝.在oracle 8i中,buffer数由db_block_buffers指定.每个buffer的大小由db_block_size指定.所以这个区域的大小是两者相乘.在oracle 9i中,这个区域的大小是db_cache_size指定.这个区不包含它们自己的控制结构,只包含database block copies data.每个buffer的header信息存在于sga的the variable area中.还有latches信息也放在sga的the variable area中.在设置db_block_buffers时每4个buffers会影响the variable area的1k的size.关于这一点.可以通过测试(针对8i而言).
the log buffer:
这个区域的size是由参数log_buffer指定的.如果os支持内存保护,log buffer将会被两个保护页面包围起来以免被一些oracle的错误进程损坏log buffer.在sga中,跟其它的如variable area和database block area相比,log buffer是非常小的.log buffer分成内部的buffer blocks,而这些block各有8个字节的头部信息存在于variable area中.
the instance lock database
在ops/rac配置中,instance locks用来控制由所有instances共享的资源以串行的方式被进入并使用.sga中的这个区域所维护的是本地实例所要使用的数据库资源,所有实例和进程都会用到的数据库资源,还有所有实例和进程当前需要的或者已经拥有的锁(locks).这三个arrays的size分别由参数lm_ress,lm_procs,lm_locks参数指定.(这三个参数是rac的参数,在单实例中用show parameter是查看不到的). the instance lock database还包含了message buffers和其它的structure.但是其size是非常小的.
这个区域的size是没办法在实例启动的时候看到的.这是oracle internals.可以用oradebug工具查看.sql>oradebug ipc.至于oradebug工具就不做介绍.用这个工具做操作时需要经过oracle support同意.
可以用以下的两种方式dump sga:
sql>alter session set events 'immediate trace name global_area level 2';
或者sql>oradebug dump global_area 2
注册会员,创建你的web开发资料库,