`
新来的菜鸟
  • 浏览: 133132 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

关于Oracle数据库work area size的讨论

 
阅读更多

单个sessionPGA内存使用量限制有比较多的概念,现在统一梳理一下:

 

1、关于PGA内存是自动管理还是手工管理,以及*_area_size(例如 sort_area_size)参数是否生效

workarea_size_policy:该参数定义数据库PGA内存是否自动管理,同时涉及到SQL运行中各种内存参数设置是否生效;当PGA内存为自动内存管理(workarea_size_policy =auto,有关SQL运行的各种内存参数设置(例如 sort_area_size 排序内存大小)均不生效,但至于SQL运行的各种内存参数设置生否真的生效,还与pga_aggregate_target值有关,具体如下:

1workarea _size_policy设置为autopga_aggregate_target设置为0 ,不会使用自动内存管理,因为当pga_aggregate_target设置为0时,workarea _size_policy自动设置为manual
2workarea _size_policy设置为manualpga_aggregate_target设置为非0,会使用自动内存管理。因为,如果设置pga_aggregate_targe为非0workarea _size_policy自动设置为auto,因此,使用自动管理。
3)如果不设置pga_aggregate_targe,那么系统缺省也是使用自动管理,并且设置该参数的值为SGA20%10M中较大的值。

 

总之:当内存为自动管理时,sort_area_size不生效;当内存为手动管理时,sort_area_size生效。

 

select name, value, isdefault, description

  from v$parameter

 where name in ('workarea_size_policy', 'pga_aggregate_target')

 or  name like 'sort%';

 

2、当PGA内存为手动管理时,*_area_size参数设置是有效的,sort_area_size参数详解:

 

sort_area_size:该参数的配置值为每个session的最大排序空间(单位:byte)。同时与该参数有关的另外一个参数是sort_area_retained_size

 

select * from v$parameter where name like '%area_size%';

 

sort_area_retained_size:该参数是控制一个session在排序结束后,该session用的内存排序区(最大为sort_area_size)降低到的空间值。例如:sort_area_size=100k, sort_area_retained_size=20k,当排序已经完成后,在记录被取出返回的过程中,oracle将逐步释放排序中使用的内存空间(例如使用了最大100k),直至释放到剩余20ksort_area_retained_size空间大小时,该session的排序内存空间将不再继续释放,sort_area_retained_size的内存空间将在排序记录的最后一条记录取走返回后再全部释放。

 

sort_area_retained_size通常设置的值与sort_area_size同样大,默认设置sort_area_retained_size=0,即与sort_area_size同样大。

10G中文档解释:SORT_AREA_SIZE specifies (in bytes) the maximum amount of memory Oracle will use for a sort. After the sort is complete, but before the rows are returned, Oracle releases all of the memory allocated for the sort, except the amount specified by the SORT_AREA_RETAINED_SIZE parameter. After the last row is returned, Oracle releases the remainder of the memory.

Each sort in a query can consume memory up to the amount specified by SORT_AREA_SIZE, and there can be multiple sorts in a query. Also, if a query is executed in parallel, each PQ slave can consume memory up to the amount specified by SORT_AREA_SIZE for each sort it does.

 

3、当PGA内存为自动管理时,允许的最大排序内存空间是多少?

 

1PGA_AGGREGATE_TARGET:该参数参数同时限制全局PGA分配和私有工作区内存分配,对于单个session可调整的内存部分(即work areas)的限制,具体如下:

a)对于串行操作,单个SQL操作能够使用的PGA内存work areas按照以下原则分配:

MIN5% * PGA_AGGREGATE_TARGET100MB

b)对于并行操作,单个SQL操作能够使用的PGA内存work areas按照以下原则分配:

30%* PGA_AGGREGATE_TARGET /DOP DOP=Degree Of Parallelism 并行度

 

select * from v$parameter where name like '%pga_aggregate_target%';

 

但我们通过v$sesstat或者v$process,可以看到有的session或者进程使用的PGA内存量大于100M,这是为什么呢?是否是上面的说明准确呢。

 

select a.sid, round(a.value/1024/1024,2)||'M' pga_area

  from v$sesstat a, v$statname b

 where a.statistic# = b.statistic#

   and b.name = 'session pga memory';

 

select pid,

       pga_used_mem / 1024 / 1024,

       pga_alloc_mem / 1024 / 1024,

       pga_freeable_mem / 1024 / 1024,

       pga_max_mem / 1024 / 1024

  from v$process;

 

2)视图v$pgastat展示了数据库当前PGA总体的使用状况

 

select * from v$pgastat

total PGA allocated:该参数显示的值是目前数据库正在使用中的PGA内存量,这个值是有可能大于PGA_AGGREGATE_TARGET配置值的。

over allocation count:该参数记录的是从数据库启动以来,PGA使用总量大于PGA_AGGREGATE_TARGET配置值的累计次数。

 

从上面的两个参数来看,在全局的范围内,PGA分配给各个session的总PGA使用量的汇总在某些情况下,是允许超过PGA_AGGREGATE_TARGET配置值的。

 

total PGA allocated - Current amount of PGA memory allocated by the instance. Oracle attempts to keep this number below the value of the PGA_AGGREGATE_TARGET initialization parameter. However, it is possible for the PGA allocated to exceed that value by a small percentage and for a short period of time when the work area workload is increasing very rapidly or when PGA_AGGREGATE_TARGET is set to a small value.

over allocation count - This statistic is cumulative since instance startup. Over allocating PGA memory can happen if the value of PGA_AGGREGATE_TARGET is too small. When this happens, Oracle cannot honor the value of PGA_AGGREGATE_TARGET and extra PGA memory needs to be allocated.

 

3)详细分析PGA的组成

首先需要说明,PGA分成两部分:

  Untunable Memory Size + Tunable Memory Size <= PGA_AGGREGATE_TARGET

这两部分各自是些什么成份﹕
a)
不可调整部分(Untunable Memory Size)PL/SQL arrays, stack space, session variables等等。如果设置的PGA(也就是PGA_AGGREGATE_TARGET的设置)小于该部分﹐那一定会超过PGA_AGGREGATE_TARGET的值﹐并且该部分是不可以shrink的,即data areas

 

b)可调整部分(Tunable Memory Size)sort area,hash area,bitmap create area, bitmap merge area 这部分也就oracle concept内所说的work areas

 

单个session在排序或者hash 时,最大允许的work areaa 是隐含参数_pga_max_size配置值的一半(隐含参数_pga_max_size的默认值为200M pga_aggregate_target参数配置值的5% 中的最小值。

 

对于并行操作,单个session操作能够使用的PGA内存work areaspga_aggregate_target参数配置值的30%除以并发度。例如:如果SQLhints PARALLEL 4pga_aggregate_target200M,那么单个session的最大PGA分配空间为15M 200M*30% / 4 = 15M )。

 

The limits of sorting and hashing

There are important limitations of pga_aggregate_target:   The total work area cannot exceed 200 megabytes of RAM because of the default setting for _pga_max_size.  No RAM sort may use more than 5% of pga_aggegate_target or _pga_max_size, whichever is smaller. This means that no task may use more than 200 megabytes for sorting or hash joins. The algorithm further reduces this to (200/2) for sorts so the actual limit for pure sorts will be 100 megabytes.

 

pga_aggegate_target *5%=_smm_max_size
pga_aggegate_target *30%=_smm_px_max_size

_
smm_px_max_size – This parameter is used for Oracle parallel query, and defaults to 30% of the pga_aggregate_target setting, divided by degree of parallelism (as set by a PARALLEL hint, "alter table xxx parallel" command, or the parallel_automatic_tuning initialization parameter). For example, by default a DEGREE=4 parallel query would have a maximum sort area value of 15 megabytes per session with a 200 megabyte pga_aggregate_target setting. Remember, parallel full-table scans bypass the data buffers and store the incoming data rows in the PGA region and not inside the data buffers (as defined by the db_cache_size parameter).

 

综上所述:PGA内存为自动管理时,pga_aggregate_target参数配置值为整个数据库的PGA内存量,单个session分配的PGA容量是有限制的,包含两部分data areaswork areas,具体为:串行操作,单个session操作能够使用的PGA内存work areas MIN5% * PGA_AGGREGATE_TARGET100MB);并行操作为30%* PGA_AGGREGATE_TARGET /DOP DOP=Degree Of Parallelism 并行度);如果单个sessionPGAdata areas载入了大量的业务数据(全表扫描,并发查询),即data areas可以超过PGA容量限制。

 

 

分享到:
评论

相关推荐

    Oracle数据库课程设计医院系统数据库源代码.zip

    Oracle数据库课程设计医院系统数据库源代码。包含Java代码和SQL语句。源码中默认使用的数据库为运行的Oracle数据库 如需修改,在java源码/database.propertie中修改即可!Oracle数据库课程设计医院系统数据库源代码...

    《Oracle 12c数据库基础教程》教学课件—03Oracle数据库管理工具.pdf

    《Oracle 12c数据库基础教程》教学课件—03Oracle数据库管理工具.pdf《Oracle 12c数据库基础教程》教学课件—03Oracle数据库管理工具.pdf《Oracle 12c数据库基础教程》教学课件—03Oracle数据库管理工具.pdf《Oracle...

    Oracle数据库大作业

    【Oracle数据库大作业】是一个关于Oracle数据库在教务管理系统中的应用项目,可能涵盖了数据库设计、实施、优化等多个方面的内容。这个大作业包含了PPT演示文稿、Word文档以及可能的源代码,为学习者提供了全面了解...

    ORACLE数据库 ORACLE数据库

    Oracle数据库是全球最广泛使用的商业关系型数据库管理系统之一,由美国甲骨文公司(Oracle Corporation)开发和维护。Oracle数据库以其高效、稳定和强大的功能在金融、电信、医疗、政府等多个领域得到广泛应用。本篇...

    Oracle数据库精讲之数据库管理_ Oracle数据库管理视频

    3. 掌握oracle数据库体系机构,为oracle优化奠定基础。 三、适合人群: 1.有意从事oracle 数据库工作,担任dba角色的人员; 2. Oracle数据库设计、开发和备份等管理人员; 四、课程内容: 第一讲:Oracle体系结构 ...

    查看登录oracle数据库用户记录.docx

    "查看登录 Oracle 数据库用户记录" Oracle 数据库是一个强大的关系型数据库管理系统,提供了强大的数据存储和管理功能。为了管理和监控数据库的访问情况,需要对登录 Oracle 数据库的用户记录进行跟踪和查看。本文...

    oracle数据库日志查看方法

    ### Oracle数据库日志查看方法详解 #### 一、概述 Oracle数据库是企业级应用中广泛使用的数据库管理系统之一,为了确保数据库系统的稳定运行和快速定位问题,掌握Oracle数据库日志查看方法至关重要。本文将详细...

    关于Oracle数据库死锁问题的研究与讨论

    关于Oracle数据库死锁问题的研究与讨论

    Oracle数据库系统应用与开发

    Oracle数据库系统是全球广泛使用的大型关系型数据库管理系统之一,它在企业级数据管理和应用程序开发中扮演着核心角色。本资源“Oracle数据库系统应用与开发”深入探讨了Oracle数据库的使用和开发技术,特别关注...

    Java导出Oracle数据库数据

    Java 导出 Oracle 数据库数据 Java 是一种流行的编程语言,广泛应用于各种领域。Oracle 是一种关系数据库管理系统,广泛应用于企业级应用中。在实际项目中,数据备份和恢复是非常重要的工作。本文将介绍如何使用 ...

    Oracle数据库使用指南

    在讨论Oracle数据库之前,我们需要了解一些基本的数据库术语,如数据库(Database)、表(Table)、记录(Record)、字段(Field)、主键(Primary Key)、索引(Index)等。数据库是存储数据的结构化集合,表是...

    Oracle数据库安装基础教程

    Oracle数据库安装基础教程

    Oracle数据库试题100题(附答案)

    Oracle数据库是甲骨文公司推出的一个功能强大的关系数据库管理系统,它广泛应用于金融、电信、制造等行业。Oracle数据库试题能够帮助相关岗位的应聘者或者数据库管理人员加深对Oracle数据库的理解。本次提供的100题...

    手工创建oracle数据库

    ### 手工创建Oracle数据库详解 #### 知识点一:手工创建Oracle数据库的环境配置与准备工作 在手工创建Oracle数据库之前,确保操作系统环境、Oracle软件版本以及必要的环境变量配置到位至关重要。根据提供的内容,...

    C#版Oracle数据库通用操作类

    ### C# 版 Oracle 数据库通用操作类解析 在现代软件开发中,数据库操作是必不可少的一部分,而 C# 结合 Oracle 数据库的应用尤为广泛。本文将深入探讨一个用于简化 Oracle 数据库操作的 C# 类——`ConnForOracle`。...

    ORACLE数据库备份用bat脚本

    在IT行业中,数据库管理是至关重要的任务之一,而Oracle数据库作为全球广泛使用的数据库管理系统,其数据安全性与备份策略显得尤为重要。本文将详细讲解如何利用批处理脚本(BAT)进行Oracle数据库的备份,并探讨...

    Oracle数据库优化之数据库磁盘IO

    7. 调整排序:使用动态表V$SYSSTAT的信息反映排序,增大SORT_AREA_SIZE以避免磁盘排序,使用NOSORT创建非排序的索引。 8. 调整Checkpoints:Checkpoint频繁发生会加快数据库的恢复,但是增加了I/O次数,会降低系统...

Global site tag (gtag.js) - Google Analytics