oracle内存结构pga,Oracle内存结构研究-PGA篇

一、概述

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的管理模式。

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时,启用自动内存管理。

三、手动PGA内存管理

有三个参数对PGA影响最大。

SORT_AREA_SIZE:对信息排序所用的内存总量

SORT_AREA_RETAINED_SIZE:排序后在内存中保存排序信息的内存总量。

HASH_AREA_SIZE:存储散列列表所用的内存量。

下面对这三个参数进行说明:

1)        SORT_AREA_SIZE:

如果SORT_AREA_SIZE设为512KB,SORT_AREA_RETAINED_SIZE也为512KB,则Oracle使用512KB的内存进行排序,排序后所有数据都留在内存中。

2)        SORT_AREA_RETAINED_SIZE:

如果SORT_AREA_SIZE设为512KB,SORT_AREA_RETAINED_SIZE设为384KB,则Oracle使用512KB的内存进行排序,然后保留384KB的已排序数据,另外512KB-384KB=128KB的已排序数据会写到临时表空间中。

        如果SORT_AREA_RETAINED_SIZE没有设置,则它的值为0,但是实际保留的排序数据和SORT_AREA_SIZE相同。

3)        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)        3,*_AREA_SIZE内存的分配是按需分配。如果一个查询需要5MB内存进行排序,就算分配1G的SORT_AREA_SIZE也不会全部使用,只会使用需要的5MB的内存量。

四、自动PGA内存管理

要启用自动PGA内存管理,设置下列参数:

1,WORKAREA_SIZE_POLICY=AUTO

2,PGA_AGGREGATE_TARGET=非零

有关PGA_AGGREGATE_TARGET:

1)        PGA_AGGREGATE_TARGET是一个目标值。连接数少的时候实际分配PGA内存会比它要小。连接数多的时候实际分配的PGA内存会比它要大,但是Oracle会努力保持总PGA保持在PGA_AGGREGATE_TARGET值内。

例 如,PGA_AGGREGATE_TARGET 设为300MB。5个用户连接时,每个用户可能分配10MB的PGA内存,共分配50MB的PGA内存。300个用户连接时每个用户可能分配1.3MB的 PGA内存,共分配390MB的PGA内存。当用户连接多时,Oracle会降低每个用户的PGA内存使用量。

2)        一个串行查询(非并行查询)可能包括多个排序/散列操作,每个排序/散列操作最多使用5%的PGA内存。

3)        一个并行查询最多可用到30%的PGA内存,无论有多少并行进程。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值