日期:2014-05-16  浏览次数:20467 次

Oracle程序全局区(PGA)

下图是共享服务器模式和专用服务器模式下,PGAUGA的不同情况

下面是专有模式的pga图:

注:上图sort area是属于pga,SORT_AREA_RETAINED_SIZE才是属于uga

1、概述
SGA,PGA,UGA,CGA都是Oracle管理的内存区。

SGA(System Global Area),即系统全局区,Oracle中最重要的内存区。
PGA(Process Global Area),即程序全局区,一个进程的专用的内存区。
UGA(User Global Area),即用户全局区,与特定的会话相关联。

CGA  (CALL Global Area),即调用全剧区,如排序区,HASH JOIN区,位图合并区等
专用服务器连接模式,UGA在PGA中分配。
共享服务器连接模式,UGA在SGA中的Large Pool中分配。

如果采用专用服务器连接模式,PGA中包含UGA,其他区域用来排序,散列和位图合并。
PGA=UGA+CGA(call global area 调用全局区=排序区+散列区+位图合并区 )

UGA=User session+Cursor state(即private SQL区)+SORT_AREA_RETAINED
 

User session区:会话信息区,存放用户权限,角色,性能统计等信息
CURSOR(私有SQL 区)就是一个句柄,即指针或引用,指向sql私有区(一个用户的能打开的cursor数由参数open_cursors决定)。然后sql私有区有指针指向共享sql区。私有sql区有两个部分

固定部分:绑定信息,数据结构信息,指针。随session的创建而创建,结束而释放(pmon)

动态部分:执行sql的中间结果集,如多表联查,排序。随sql的创建而创建,结束而释放。
2、PGA的管理模式。
PGA分两种管理模式:
1)        手动PGA内存管理,用户指定排序区和散列区所使用的内存,每个连接使用相同的内存。
2)        自动PGA内存管理,告诉Oracle可以使用的PGA的总量,由Oraclce根据系统负载决定具体分配。

        9iR1时默认为手动PGA内存管理,9iR2以后默认为自动PGA内存管理。
        PGA内存可以动态扩大和回收。

PGA内存管理模式由WORKAREA_SIZE_POLICY控制。
1)        设为MANUAL,启用手动内存管理。
2)        设为AUTO,并且PGA_AGGREGATE_TARGET不为0时,启用自动内存管理。


3、手动PGA内存管理
有三个参数对PGA影响最大。