Oracle内存管理(之二)

【深入解析--eygle】 学习笔记

1.2.2 UGA和CGA

UGA(用户全局区)由用户会话数据、游标状态和索引区组成。在共享服务器模式下,一个共享服务进程被多个用户进程共享,此时UGA是Shared Pool或Large Pool的一部分,而在专用服务器模式下,UGA则是PGA的一部分。

不考虑Shared  Server模式,在Dedicated模式下,PGA与UGA关系,就如同Process和Session的关系,PGA是服务于进程的内存结构,包含进程信息;而UGA是服务于会话的,它包含的是会话的信息。UGA中包含如下信息:

(1)打开游标的永久区和运行区;

(2)包的状态信息以及变量信息;

(3)Java会话的状态信息;

(4)启用角色信息、跟踪事件;

(5)起作用的NLS参数;

(6)所有打开的database links;

(7)会话访问控制信息等

UGA也由两组区组成,固定UGA和可变UGA(或者说UGA堆)。固定UGA包含了大概70个原子变量、小的数据结构以及指向UGA堆的指针。

UGA中的内存分配可以通过内部表X$KSMUP(X$KSMUP - [K]ernel [S]ervice[M]emory [U]GA Hea[P])查询得到UGA堆包含了存储一些固定表(X$表)的永久内存(依赖于特定参数的设置,如OPEN_CURSORS,OPEN_LINKS和MAX_ENABLED_ROLES)。

[email protected] SQL>select ADDR,KSMCHCOM,KSMCHPTR,KSMCHSIZ,KSMCHCLS,KSMCHTYP,KSMCHPAR from x$ksmup;

ADDR             KSMCHCOM                         KSMCHPTR           KSMCHSIZ KSMCHCLS           KSMCHTYP KSMCHPAR

------------------------------------------------ ---------------- ---------- -------------------------- --

00007F528F1D6920dbgdInitEventGr                 00007F528F23FFB0         80freeabl                   0 00

00007F528F1D68C8 sessionlanguag                 00007F528F23FD60        592freeabl                   0 00

00007F528F1D6870 SessionNCHAR l                 00007F528F23FB10        592freeabl                   0 00

00007F528F1D6818 kdlw:UGAstate                  00007F528F23FAC8         72freeabl                   0 00

00007F528F1D67C0 kdlu:UGAstate                   00007F528F23FAA0         40 freeabl                   0 00

00007F528F1D6768kzsrcrdi                        00007F528F23F960        320freeabl                   0 00

00007F528F1D6710kzctxhugi1                      00007F528F23E948       4120 freeabl                   0 00

00007F528F1D66B8 PLS ccahp desc                 00007F528F23E7D0        376freeabl                   0 00

00007F528F1D6660 PLS ccahp desc                 00007F528F23E658        376freeabl                   0 00

00007F528F1D6608 PLS UGAhp                      00007F528F23DE50       2056recr                   409500007F528F23E7E8

00007F528F1D65B0 kgsc htsegs                    00007F528F23DE30         32freeabl                   0 00

00007F528F1D6558 kgsc htsegs                    00007F528F23DE10         32freeabl                   0 00

00007F528F1D6500 kgsc htsegs                    00007F528F23DDF0         32freeabl                   0 00

00007F528F1D64A8 kgsc htsegs                     00007F528F23DDD0         32 freeabl                   0 00

00007F528F1D6450 kgsc htsegs                    00007F528F23DDB0         32freeabl                   0 00

00007F528F1D63F8 kgsc htsegs                    00007F528F23DD90         32freeabl                   0 00

00007F528F1D63A0 kgsc htsegs                    00007F528F23DD70         32freeabl                   0 00

00007F528F1D6348 kgsc htsegs                    00007F528F23DD50         32freeabl                   0 00

00007F528F1D62F0 kgsc htsegs                    00007F528F23DD30         32freeabl                   0 00

00007F528F1D6298 kgsc htsegs                    00007F528F23DD10         32freeabl                   0 00

00007F528F1D6240 kgsc htsegs                     00007F528F23DCF0         32 freeabl                   0 00

00007F528F1D61E8 kgsc htsegs                    00007F528F23DCD0         32freeabl                   0 00

00007F528F1D6190 kgsc htsegs                    00007F528F23DCB0         32freeabl                   0 00

00007F528F1D6138 kgsc htsegs                    00007F528F23DC90         32freeabl                   0 00

00007F528F1D60E0 kgsc htsegs                    00007F528F23DC70         32freeabl                   0 00

从Oracle9iR2开始,有一系列新的隐含参数被引入用于控制自动的PGA管理,这其中有一个关键的参数是_use_realfree_heap,当设置这个参数为true时,Oracle会为CGA、UGA单独分配堆,而不从PGA中分配。它的默认值为false,而当设置了pga_aggregate_target后,它的值自动被改为true:

SQL>SELECT x.ksppinm NAME, y.ksppstvl VALUE,x.ksppdesc describ

FROMSYS.x$ksppi x, SYS.x$ksppcv y

WHEREx.indx = y.indx AND x.ksppinm LIKE ‘%&par%‘;

Enter value for par: realfree

old   3:WHERE x.indx = y.indx AND x.ksppinm LIKE ‘%&par%‘

new   3:WHERE x.indx = y.indx AND x.ksppinm LIKE ‘%realfree%‘

NAME                                     VALUE         DESCRIB

----------------------------------------------------- -----------------------------------------

_realfree_heap_max_size                  32768         minimum max total heap size, in Kbytes

_realfree_heap_pagesize_hint             65536         hint for real-free page size in bytes

_realfree_heap_mode                      0             mode flags for real-free heap

_use_realfree_heap                       TRUE          use real-free based allocator for PGAmemory

SQL>

_use_realfree_heap
是自动管理PGA技术的关键技术变化,realfree代表着实时释放。Oracle9i之前手工管理的PGA的主要问题在于,UGA缺省的在PGA中分配,当会话执行了诸如排序、HASH-JOIN等操作,耗用了大量PGA内存,而当会话执行完毕之后,内存会释放给PGA而不是OS,在很多时候这会导致过度的PGA内存使用(在以前版本PGA内存分配和回收是通过malloc()以及brk()调用来完成的);从Oracle9iR2开始,自动的PGA内存管理当_use_realfree_heap为true时,PGA的内存分配将会通过mmap()调用来实现,这样当调用结束时将不必将内存返回给进程而直接返回给OS,从而实现了更好的PGA内存分配与使用。

通过V$PGASTAT视图可以查询PGA累计释放回OS的内存空间:

SQL> select name,value from v$pgastat wherename like ‘%OS‘;

NAME                                          VALUE

---------------------------------------- -----------

PGA memory freed back to OS                175374336

下图是UGA的结构示意图:

在PGA的示意图中,还涉及了另外一块内存区域被称为CGA(Call Global  Area)-调用全局区。与其他的全局区不同,CGA的存在是瞬间的,只存在于调用过程中,而且无论UGA存在于PGA还是SGA,CGA都是PGA的SubHeap。对
于 实 例 的 一 些 低 层 次 的 调 用(Low-Level Call
)需要CGA,包括分析SQL语句、执行SQL语句以及获取查询结果都需要使用CGA,在SQL执行过程中的每个递归调用需要一个独立的CGA,在SQL的解析过程中,查询数据字典信息、对SQL进行语法以及语义的解析、SQL的优化以及不同执行计划的评估都需要使用CGA。

当然,调用并不是只通过CGA中的数据结构来工作,实际上调用所需要的大部分的重要数据结构都来自于UGA(如SQL AREA, PL/SQL AREA,Sort Area都存放在UGA中,因为这些结构在调用期间需要一直可用),CGA中只包含了那些调用结束后可以被释放的数据。例如,CGA中包含了Direct
I/O BUFFER、递归调用信息、表达式评估的堆栈信息等,此外Java调用内存也在CGA中分配。

Oracle内存管理(之二),布布扣,bubuko.com

时间: 2024-10-10 09:09:23

Oracle内存管理(之二)的相关文章

Oracle内存管理理论篇二

目标 了解oracle内存管理方式 掌握ASMM管理方式 掌握AMM管理方式 监控内存使用 学习一个知识点时,最好先了解其历史.ORACLE近期的版本都对内存管理做了简化,从9i通过PGA_AGGREGATE_TARGET参数实现PGA的自动管理,10g通过Automatic Shared Memory Management(ASMM)实现SGA的自动管理,到11g通过Automatic Memory Management(AMM)实现内存(SGA+PGA)的自动管理.目前的11G版本,DBA只

黑马程序员----内存管理之二《多对象的内存管理》

内存管理之二——<多对象的内存管理> 1.多对象的内存管理方式: 只要有人使用了这个对象,这个对象就不能被销毁: 只要你想使用这个对象,就让这个对象的引用计数器的值+1(让对象做一次retain操作): 当你不再使用这个对象,就让这个的对象的引用计数器的值-1(让对象做一次release操作): 谁alloc,谁就release: 谁retain,谁就release: 2.内存管理的代码规范: 只要调用了alloc必须有release/autorelease set方法的代码规范: 1.基本数

Oracle内存管理(之五)

[深入解析--eygle]学习笔记 1.4. 2其他内存组件 Large Pool-大池是SGA的一个可选组件,通常用于共享服务器模式(MTS). 并行计算或 RMAN的备份恢复等操作. Java Pool-Java池主要用于JVM等Java选件. Streams Pool-Streams pool是Oracle10g引入的概念,为Oracle的Streams功能所使用,如果不定义该参数,这部分内存将从Shread Pool中分配 对于SGA各部分内存分配,可以从数据库的视图中查询得到: 17:

Oracle内存管理(之四)

[深入解析--eygle]学习笔记 1.3 SGA管理 SGA指系统全局区(System Global Area),是一块用于加载数据.对象并保存运行状态和数据库控制信息的一块内存区域,在数据库实例启动时分配,当实例关闭时释放,每个实例都拥有自己的SGA区. 在第一章曾经?到,当数据库启动到nomount状态时,SGA已经分配,同时启动后台进程,在SQL*Plus中通过show sga命令可以看到SGA的分配情况: [email protected] SQL>show parameter sga

oracle内存管理

参考文章 参考文章 参考文章 参考文章 参考文章 oracle内存管理,布布扣,bubuko.com

垃圾回收GC:.Net自己主动内存管理 上(二)内存算法

垃圾回收GC:.Net自己主动内存管理 上(二)内存算法 垃圾回收GC:.Net自己主动内存管理 上(一)内存分配 垃圾回收GC:.Net自己主动内存管理 上(二)内存算法 垃圾回收GC:.Net自己主动内存管理 上(三)终结器 前言 .Net下的GC全然攻克了开发人员跟踪内存使用以及控制释放内存的窘态.然而,你或午想要理解GC是怎么工作的.此系列文章中将会解释内存资源是怎么被合理分配及管理的,并包括很具体的内在算法描写叙述.同一时候.还将讨论GC的内存清理流程及什么时清理,怎么样强制清理. 内

垃圾回收GC:.Net自动内存管理 上(二)内存算法

垃圾回收GC:.Net自动内存管理 上(二)内存算法 垃圾回收GC:.Net自动内存管理 上(一)内存分配 垃圾回收GC:.Net自动内存管理 上(二)内存算法 前言 .Net下的GC完全解决了开发者跟踪内存使用以及控制释放内存的窘态.然而,你或午想要理解GC是怎么工作的.此系列文章中将会解释内存资源是怎么被合理分配及管理的,并包含非常详细的内在算法描述.同时,还将讨论GC的内存清理流程及什么时清理,怎么样强制清理. 内存算法 GC检测用于查看堆中是否有对象不再被程序使用.如果这样的对象存在,这

【读书笔记】ORACLE 内存管理

<Administrator's Guide>第6章介绍了ORACLE实例的内存管理,在11g中,ORACLE默认使用自动内存管理(AMM)来管理SGA和PGA的大小.除了默认的方法之外,还可以使用自动共享内存管理SGA(ASMM).手动共享内存管理SGA.自动PGA内存管理.手动PGA内存管理. 一.自动内存管理 自动内存管理是最方便的内存管理方式,只需要设定参数MEMORY_TARGET的值,ORACLE 就会根据实际需要分配SGA和PGA. 1.1应用自动内存管理 1.用SYSDBA的身

Oracle 内存管理

--内存分配建库时可以先分配系统内存的50%-80%给Oracle,后期根据业务再进行调整.SGA.PGA分配比例:OLTP:SGA %80 , PGA %20OLAP:SGA %50 , PGA %50混合:SGA %60 , PGA %40 --sga自动管理statistics_level 值设置为 typical 或 all,启动 sga 自动管理.给定 sga_target 一个总的数值. --sga手动管理设置 sga_target=0 ,设置相关组件大小:java_pool_siz