32bit的Oracle的SGA通常最多可使用内存 1.7G
经验值,对于OLTP
1G RAM SharedPool 100M, DataBuffer 500M
2G RAM SharedPool 150M, DataBuffer 1200M
对于64bit的Oracle,
4G RAM SharedPool 200M, DataBuffer 2500M
8G RAM SharedPool 300M, DataBuffer 5000M
经常被问到,在安装Oracle时SGA与PGA占总内存多少比例合适的问题。
这里给出我的一点点经验。
假设主机的总物理内存是100G。
如果要部署OLTP系统,可以如下的比例进行分配:
20G -- 操作系统及其他预留
64G -- Oracle的SGA
16G -- Oracle的PGA
如果部署的是DSS或DW类型的数据库,可以适当的加大PGA的大小,可以考虑按照下面的比例进行分配:
20G -- 操作系统及其他预留
40G -- Oracle的SGA
40G -- Oracle的PGA
以上只是我在部署测试环境时一般的分配策略。具体环境要具体分析,尤其是在部署生产环境的时候,要更多的考虑到未来系统主要倾向于什么样的业务类型,对SGA及PGA的比例关系也是各不相同的,在真正上线之前一定要做最充分的“基线测试”。
还有一个小原则要记住:对于主机物理内存小于1G的,并且部署的数据库类型是专有服务器模式(Dedicated),通常Oracle的SGA内存分配不要超过总内存的一半,否则很有可能因为内存紧张导致Oracle运行过程中出现瓶颈。切记切记!
一、名词解释
(1)SGA:System Global Area是Oracle Instance的基本组成部分,在实例启动时分配;系统全局域SGA主要由三部分构成:共享池、数据缓冲区、日志缓冲区。
(2)共享池:Shared Pool用于缓存最近被执行的SQL语句和最近被使用的数据定义,主要包括:Library cache(共享SQL区)和Data dictionary cache(数据字典缓冲区)。 共享SQL区是存放用户SQL命令的区域,数据字典缓冲区存放数据库运行的动态信息。
(3)缓冲区高速缓存:Database Buffer Cache用于缓存从数据文件中检索出来的数据块,可以大大提高查询和更新数据的性能。
(4)大型池:Large Pool是SGA中一个可选的内存区域,它只用于shared server环境。
(5)Java池:Java Pool为Java命令的语法分析提供服务。
(6)PGA:Process Global Area是为每个连接到Oracle database的用户进程保留的内存。
二、分析与调整
(1)系统全局域:
SGA与操作系统、内存大小、cpu、同时登录的用户数有关。可占OS系统物理内存的1/3到1/2。
a.共享池:
查看共享SQL区的使用率:
- select(sum(pins-reloads))/sum(pins) "Library cache" from v$librarycache;
这个使用率应该在90%以上,否则需要增加共享池的大小。
查看数据字典缓冲区的使用率:
- select (sum(gets-getmisses-usage-fixed))/sum(gets) "Data dictionary cache" from v$rowcache;
这个使用率也应该在90%以上,否则需要增加共享池的大小。
修改共享池的大小:
- ALTER SYSTEM SET SHARED_POOL_SIZE = 64M;
b.缓冲区高速缓存:
查看数据库数据缓冲区的使用情况:
- SELECT name,value FROM v$sysstat order by name WHERE name IN(''DB BLOCK GETS'',''CONSISTENT GETS'',''PHYSICAL READS'');
计算出来数据缓冲区的使用命中率=1-(physical reads/(db block gets+consistent gets)),这个命中率应该在90%以上,否则需要增加数据缓冲区的大小。
c.日志缓冲区
查看日志缓冲区的使用情况:
- SELECT name, value FROM v$sysstat WHERE name IN (''redo entries'',''redo log space requests'');
查询出的结果可以计算出日志缓冲区的申请失败率:
申请失败率=requests/entries,申请失败率应该接近于0,否则说明日志缓冲区开设太小,需要增加ORACLE数据库的日志缓冲区。
d.大型池:
可以减轻共享池的负担,可以为备份、恢复等操作来使用,不使用LRU算法来管理。其大小由数据库的‘共享模式/db模式’如果是共享模式的话,要分配的大一些。
指定Large Pool的大小:
- ALTER SYSTEM SET LARGE_POOL_SIZE=64M
e.Java池:
在安装和使用Java的情况下使用。
(2)PGA调整
a.PGA_AGGREGATE_TARGET初始化设置
PGA_AGGREGATE_TARGET的值应该基于Oracle实例可利用内存的总量来设置,这个参数可以被动态的修改。假设Oracle实例可分配4GB的物理内存,剩下的内存分配给操作系统和其它应用程序。你也许会分配80%的可用内存给Oracle实例,即3.2G。现在必须在内存中划分SGA和PGA区域。
在OLTP(联机事务处理)系统中,典型PGA内存设置应该是总内存的较小部分(例如20%),剩下80%分配给SGA。
OLTP:PGA_AGGREGATE_TARGET = (total_mem * 80%) * 20%
在DSS(数据集)系统中,由于会运行一些很大的查询,典型的PGA内存最多分配70%的内存。
DSS:PGA_AGGREGATE_TARGET = (total_mem * 80%) * 50%
在这个例子中,总内存4GB,DSS系统,你可以设置PGA_AGGREGATE_TARGET为1600MB,OLTP则为655MB。
b.配置PGA自动管理
不用重启DB,直接在线修改。
SQL> alter system set workarea_size_policy=auto scope=both;
System altered.
SQL> alter system set pga_aggregate_target=512m scope=both;
System altered.
SQL> show parameter workarea
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
workarea_size_policy string AUTO --这个设置成AUTO
SQL> show parameter pga
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
pga_aggregate_target big integer 536870912
SQL>
c.监控自动PGA内存管理的性能
V$PGASTAT:这个视图给出了一个实例级别的PGA内存使用和自动分配的统计。
SQL> set lines 256
SQL> set pages 42
SQL> SELECT * FROM V$PGASTAT;
NAME VALUE UNIT
---------------------------------------------------------------- ---------- ------------
aggregate PGA target parameter 536870912 bytes --当前PGA_AGGREGATE_TARGET的值
aggregate PGA auto target 477379584 bytes --当前可用于自动分配了的PGA大小,应该比PGA_AGGREGATE_TARGET 小
global memory bound 26843136 bytes --自动模式下工作区域的最大大小,Oracle根据工作负载自动调整。
total PGA inuse 6448128 bytes
total PGA allocated 11598848 bytes --PGA的最大分配
maximum PGA allocated 166175744 bytes
total freeable PGA memory 393216 bytes --PGA的最大空闲大小
PGA memory freed back to OS 69074944 bytes
total PGA used for auto workareas 0 bytes --PGA分配给auto workareas的大小
maximum PGA used for auto workareas 1049600 bytes
total PGA used for manual workareas 0 bytes
maximum PGA used for manual workareas 530432 bytes
over allocation count 1118 --实例启动后,发生的分配次数,如果这个值大于0,就要考虑增加pga的值
bytes processed 114895872 bytes
extra bytes read/written 4608000 bytes
cache hit percentage 96.14 percent --命中率
16 rows selected.
--V$PGA_TARGET_ADVICE
SQL> SELECT round(PGA_TARGET_FOR_ESTIMATE/1024/1024) target_mb,
ESTD_PGA_CACHE_HIT_PERCENTAGE cache_hit_perc,
ESTD_OVERALLOC_COUNT
FROM v$pga_target_advice;
The output of this query might look like the following:
TARGET_MB CACHE_HIT_PERC ESTD_OVERALLOC_COUNT
---------- -------------- --------------------
63 23 367
125 24 30
250 30 3
375 39 0
500 58 0
600 59 0
700 59 0
800 60 0
900 60 0
1000 61 0
1500 67 0
2000 76 0
3000 83 0
4000 85 0
可以看出当TARGET_MB 为375M是ESTD_OVERALLOC_COUNT=0,所以可以将PGA_AGGREGATE_TARGET设置成375M。
附:oracle SGA与PGA区别:
SGA:是用于存储数据库信息的内存区,该信息为数据库进程所共享。它包含Oracle 服务器的数据和控制信息,它是在Oracle服务器所驻留的计算机的实际内存中得以分配,如果实际内存不够再往虚拟内存中写。
PGA:包含单个服务器进程或单个后台进程的数据和控制信息,与几个进程共享的SGA 正相反,PGA 是只被一个进程使用的区域,PGA 在创建进程时分配,在终止进程时回收。
分享到:
相关推荐
SGA+PGA最好不要超过总内存的70%,内存详细调整方案,供学习。
Oracle数据库系统是企业级数据管理的重要工具,其中的SGA(System Global Area)和PGA(Program Global Area)是两个核心概念,对于理解Oracle数据库的工作原理至关重要。本文将深入探讨这两个概念,以及它们在...
Oracle数据库的内存结构主要包括三个关键部分:System Global Area (SGA), Program Global Area (PGA), 和 User Global Area (UGA)。这些区域都是用于存储和处理数据库操作的数据和信息。 1. **System Global Area ...
这里我们将`SGA`目标大小设置为8GB,`PGA`目标大小设置为2GB。同样地,这些更改是持久化的,需要重启数据库才能生效。 ```sql SQL> create pfile from spfile; SQL> shutdown immediate; SQL> startup; ``` #### 小...
根据系统类型、DB版本和OS内存自动计算Oralce建议的memory_target、SGA和PGA大小
在Oracle数据库管理中,了解和优化程序全局区(PGA)和系统全局区(SGA)的内存分配至关重要,这直接关系到数据库服务器性能的高效运行。以下是对PGA、SGA以及如何合理配置数据库服务器内存的深入解析。 ### PGA...
OracleSGA和PGA管理
oracle11g10g安装备份基础维护
### Oracle实例内存优化详解:SGA与PGA的调整策略 #### 概述 在Oracle数据库管理系统中,优化数据库性能往往涉及到对其内部结构的理解与微调,尤其是针对内存资源的合理分配。本文将深入探讨Oracle实例的内存管理...
下面将详细介绍如何更改 Oracle SGA 的大小,以及在出现问题时如何恢复到初始设置。 1. **查询 SGA 参数**: 在命令行中,使用 `sqlplus` 登录到数据库,以 `sysdba` 角色连接: ``` sqlplus /nolog Conn / as ...
在进行SGA和PGA的设置时,有几个关键点需要注意。首先,应确保数据库有充足的内存供Oracle使用,同时考虑到操作系统和其他应用程序的需求。其次,对于32位系统,SGA通常有一个1.7GB的限制,而在64位系统中,这个限制...
4. **会话级PGA管理**:通过设置会话级别的PGA限制,如`_sort_area_size`、`hash_area_size`等,可以控制特定会话的资源使用,防止个别会话过度消耗PGA资源,影响其他会话的性能。 5. **监控与分析**:利用V$PGA_...
这一特性允许数据库根据实际的处理需求动态地调整内存区域的大小,如sort_area_size、pga_aggregate_target、large_pool_size、sga_max_size和db_cache_size。这些内存区域分别服务于排序操作、PL/SQL程序执行、大...
- 在提供的示例中,`Memory_target`设置为1552M,`Sga_target`设置为0,这表明SGA的自动管理正在运行,但SGA没有特定的上限,其大小由`Memory_target`决定。 - 共享池的大小显示为0,表示它也在自动管理之下。`db_...
#### 一、SGA与PGA基本概念 - **SGA (System Global Area)**:系统全局区是Oracle实例启动时分配的共享内存区域,用于存储数据和控制信息。它包括多个部分,如共享池、数据缓冲区、日志缓冲区等。 - **共享池**:...
SGA(SystemGlobalArea):由所有服务进程和后台进程共享;PGA(ProgramGlobalArea):由每个服务进程、后台进程专有;每个进程都有一个PGA。包含实例的数据和控制信息,包含如下内存结构:1)Databasebuffercache:缓存...
过多的并发连接可能导致PGA资源紧张,合理设置最大连接数和分配给每个会话的内存是必要的。 2. **Sort Area**:在执行排序操作(如ORDER BY、GROUP BY)时,Oracle会在PGA中分配空间。根据查询复杂性调整排序区大小...
- ** PGA (Program Global Area)**:虽然不是SGA的一部分,但与之相关,每个用户进程都有自己的PGA,存储私有数据和临时结果。 2. **32位系统的内存限制** 在32位操作系统中,由于地址线的数量限制,最多只能直接...