当前位置:   article > 正文

oracle的内存管理区之PGA_oracle rac 将pga由自动管理改为手动

oracle rac 将pga由自动管理改为手动
 

1. SGA,PGA,UGA都是Oracle管理的内存区。

SGA(System Global Area),即系统全局区,Oracle中最重要的内存区。
PGA(Process Global Area),即程序全局区,一个进程的专用的内存区。
UGA(User Global Area),即用户全局区,与特定的会话相关联。
专用服务器连接模式,UGA在PGA中分配。
共享服务器连接模式,UGA在SGA中的Large Pool中分配。

如果采用专用服务器连接模式,PGA中包含UGA,其他区域用来排序,散列和位图合并。
简单来讲,PGA=UGA+排序区+散列区+位图合并区。

PGA和UGA两者的区别更一个进程和一个会话之间的区别类似的。尽管说进程和会话一半是一对一的关系,但是实际比这个复杂。在MTS配置下,会话往往会比进程多得多,每一个进程会友一个PGA,每一个会话会友一个UGA。PGA所包含的信息跟会话是无任何关系的,而UGA包含的信息是以特定的会话为基础。

2. PGA的管理模式
PGA的管理模式分两种,手动和自动,PGA内存管理模式由WORKAREA_SIZE_POLICY控制。

a.  设为MANUAL,启用手动内存管理。
b.  设为AUTO,并且PGA_AGGREGATE_TARGET不为0时,启用自动内存管理。

手动PGA内存管理,用户指定排序区和散列区所使用的内存,每个连接使用相同的内存。
自动PGA内存管理,告诉Oracle可以使用的PGA的总量,由Oraclce根据系统负载决定具体分配。

3. 手动PGA内存管理

有三个参数对PGA有影响
SORT_AREA_SIZE:对信息排序所用的内存总量
SORT_AREA_RETAINED_SIZE:排序后在内存中保存排序信息的内存总量。

如果SORT_AREA_SIZE设为512KB,SORT_AREA_RETAINED_SIZE也为512KB,则Oracle使用512KB的内存进行排序,排序后所有数据都留在内存中。
如果SORT_AREA_SIZE设为512KB,SORT_AREA_RETAINED_SIZE也为300KB,则Oracle使用512KB的内存进行排序,然后保留300KB的已排序数据,另外212KB已排序的数据会写到临时表空间中。
如果SORT_AREA_RETAINED_SIZE没有设置,则它的值为0,但是实际保留的排序数据和SORT_AREA_SIZE相同。

HASH_AREA_SIZE:存储散列列表所用的内存量。
一个大集合和另外一个稽核进行连接时,会使用到HASH_AREA_SIZE参数,较小的表会放到这部分内存中作为驱动表,然后对达标进行探索(PROBE)操作进行连接。如果HASH_AREA_SIZE过小会影响两个表连接时的性能。

注意点:
1)        如果需要排序的数据量大于SORT_AREA_SIZE,Oracle会分批进行排序。把当前已排序的数据保存到临时表空间中,然后对剩余的数据进行排序。最后,还会对这些保存在临时表空间中的已排序数据再进行排序,因为每次保存到临时表空间中的已排序数据只是部分数据的排序,对整体需排序的数据来说只是部分局部有序。
2)        *_AREA_SIZE只是对某个操作的限制,一个查询可能有多个操作,每个操作都有自己的内存区。如果SORT_AREA_SIZE设为5MB,一个查询可能会有10个排序操作,这样一个查询会占用50MB的排序内存。
3)        *_AREA_SIZE内存的分配是按需分配。如果一个查询需要5MB内存进行排序,就算分配1G的SORT_AREA_SIZE也不会全部使用,只会使用需要的5MB的内存量。


4.自动PGA内存管理


要启用自动PGA内存管理,设置下列参数:
1,WORKAREA_SIZE_POLICY=AUTO
2,PGA_AGGREGATE_TARGET=非零

a.PGA_AGGREGATE_TARGET是PGA内存的一个目标值,连接数少的时候实际分配PGA内存会比它要小,连接多的时候实际分配的PGA内存会比它要大(不够会向large_pool借),并且oracle会降低每个用户的PGA内存使用量,但是Oracle会努力保持总PGA保持在PGA_AGGREGATE_TARGET值内。
b.一个串行查询(非并行查询)可能包括多个排序/散列操作,每个排序/散列操作最多使用5%的PGA内。
c.一个并行查询最多可用到30%的PGA内存,无论有多少并行进程。

5.查看相关参数

SQL> show parameters hash
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
hash_area_size                       integer     131072
 
SQL> show parameters WORKAREA_SIZE_POLICY
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
workarea_size_policy                 string      AUTO
 
SQL> show parameters sort_
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
sort_area_retained_size              integer     0
sort_area_size                       integer     65536
 

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号