`

关于SGA的设置

阅读更多

关于SGA设置的一点总结,itpub论坛.biti_rainy老大的文章,很是不错,就留了一份,当作优化oracle的参考!


关于SGA设置的一点总结
本总结不针对特例,仅对服务器只存在OS + ORACLE 为例,如果存在其他应用请酌情考虑写这个也是因为近来这种重复性的问题发生的太多所导致的.
首先不要迷信STS,SG,OCP,EXPERT 等给出的任何建议、内存百分比的说法
基本掌握的原则是, data buffer 通常可以尽可能的大,shared_pool_size 要适度,log_buffer 通常大到几百K到1M就差不多了。

设置之前,首先要明确2个问题
1: 除去OS和一些其他开销,能给ORACLE使用的内存有多大
2:oracle是64bit or 32 bit,32bit 通常 SGA有 1.7G 的限制(某些OS的处理或者WINDOWS上有特定设定可以支持到2G以上甚至达到3.7G,本人无这方面经验)

下面是我的windows2000下的oracle :

SQL> select * from v$version;

BANNER
----------------------------------------------------------------
Oracle8i Enterprise Edition Release 8.1.7.0.0 - Production
PL/SQL Release 8.1.7.0.0 - Production
CORE 8.1.7.0.0 Production
TNS for 32-bit Windows: Version 8.1.7.0.0 - Production
NLSRTL Version 3.4.1.0.0 - Production

SQL>

windows上存在32bit的限制,如AIX、HP UNIX 等有明确的64BIT OS and ORACLE的版本,32bit oracle可以装在64bit os 上,64 bit oracle不能装在32 bit OS上。

不管oracle是32 bit ORACLE还是 64 bit 的,假定应用存在没有很好的使用bind var 的情况,也不能设置 shared_pool_size 过大,通常应该控制在200M--300M,如果是 ORACLE ERP 一类的使用了很多存储过程函数、包 ,或者很大的系统,可以考虑增大shared_pool_size ,但是如果超过500M可能是危险的,达到1G可能会造成CPU的严重负担,系统甚至瘫痪。所以shared_pool_size 如果超过300M还命中率不高,那么应该从应用上找原因而不是一味的增加内存,shared_pool_size 过大主要增加了管理负担和latch 的开销。

log_buffer : 128K ---- 1M 之间通常问题不大,不应该太大。

large_pool_size :如果不设置MTS,通常在 RMAN 、OPQ 会使用到,但是在10M --- 50M 应该差不多了。假如设置 MTS,则由于 UGA 放到large_pool_size 的缘故,这个时候依据 session最大数量和 sort_ares_size 等参数设置,必须增大large_pool_size 的设置,可以考虑为 session * (sort_area_size + 2M)。这里要提醒一点,不是必须使用MTS,我们都不主张使用MTS,尤其同时在线用户数小于500的情况下。

java_pool_size : 若不使用java,给30M通常就够了。

data buffer ,在做了前面的设置后,凡可以提供给oracle的内存,都应该给data buffer = (db_block_size * db_block_buffers)
在9i 中可以是 db_cache_size

还有2个重要参数我们需要注意

sort_area_size and hash_area_size
这两个参数在非MTS下都是属于PGA ,不属于SGA,是为每个session单独分配的,在我们的服务器上除了OS + SGA,一定要考虑这两部分

(****) : OS 使用内存+ SGA + session*(sort_area_size + hash_area_size + 2M) < 总物理RAM 为好。


这样归结过来,假定oracle是 32 bit ,服务器RAM大于2G ,注意你的PGA的情况,,则建议

shared_pool_size + data buffer +large_pool_size + java_pool_size < 1.6G


再具体化,注意满足上面(****) 的原则的基础上可以参考如下设置
如果512M RAM
建议 shared_pool_size = 50M, data buffer = 200M

如果1G RAM
shared_pool_size = 100M , data buffer = 500M

如果2G
shared_pool_size = 150M ,data buffer = 1.2G

物理内存再大已经跟参数没有关系了
假定64 bit ORACLE

内存4G
shared_pool_size = 200M , data buffer = 2.5G

内存8G
shared_pool_size = 300M , data buffer = 5G

内存 12G
shared_pool_size = 300M-----800M , data buffer = 8G

以上仅为参考值,不同系统可能差异比较大,需要根据具体情况调整。建议在设置参数的同时,init中使用 lock_sga ,在不同的平台上可能有不同的方式,使得SGA锁定在物理内存中而不被放入 SWAP 中,这样对效率有好处。
关于内存的设置,要再进行细致的调整,起的作用不大,但可根据statspack信息和v$system_event,v$sysstat,v$sesstat,v$latch 等view信息来考虑微调。
附件:
案例分析:
案例描述:
用户报告,服务器启动一段时间以后,无法建立数据库连接
重新启动几分钟以后,再次无法连接,系统无法正常使用.
1:登陆系统
2.su 为Oracle用户
检查启动的Oracle进程
wapplatform:/>su - oracle
/export/home1/oracle>ls
export/home1/oracle>cd admin
/export/home1/oracle/admin>ps -ef|grep ora
3.检查Alert.log警报日志文件
4.尝试连接数据库
$ sqlplus "/ as sysdba"
SQL*Plus: Release 9.2.0.3.0 - Production on 星期二 3月 23 14:14:06 2004
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
ERROR:
ORA-12540: TNS: 超出内部限制
5.检查监听器
/export/home1/oracle>lsnrctl services
[oracle@localhost oracle]$ lsnrctl services
LSNRCTL for Linux: Version 9.2.0.1.0 - Production on 16-NOV-2005 15:49:52 Copyright (c) 1991, 2002, Oracle Corporation. All rights reserved.
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC)))
Services Summary...
Service "PLSExtProc" has 1 instance(s).
Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
Handler(s):
"DEDICATED" established:0 refused:0
LOCAL SERVER
Service "cicro" has 2 instance(s).
Instance "test", status UNKNOWN, has 1 handler(s) for this service...
Handler(s):
"DEDICATED" established:0 refused:0
LOCAL SERVER
Instance "test", status READY, has 1 handler(s) for this service...
Handler(s):
"DEDICATED" established:0 refused:0 state:ready
LOCAL SERVER
Service "gao.web" has 1 instance(s).
Instance "gaogao", status READY, has 1 handler(s) for this service...
Handler(s):
"DEDICATED" established:319 refused:0 state:ready
LOCAL SERVER
Service "gaogaoXDB.web" has 1 instance(s).
Instance "gaogao", status READY, has 1 handler(s) for this service...
Handler(s):
"D000" established:0 refused:0 current:0 max:1002 state:ready
DISPATCHER <machine: localhost.localdomain, pid: 1752>
(ADDRESS=(PROTOCOL=tcp)(HOST=localhost.localdomain)(PORT=46746))
Service "testXDB" has 1 instance(s).
Instance "test", status READY, has 1 handler(s) for this service...
Handler(s):
"D000" established:0 refused:0 current:0 max:1002 state:ready
DISPATCHER <machine: localhost.localdomain, pid: 5285>
(ADDRESS=(PROTOCOL=tcp)(HOST=localhost.localdomain)(PORT=46900))
The command completed successfully
6.退出Oracle用户检查
/export/home1/oracle/admin/hswapdb/bdump>exit
wapplatform:/>dmesg
7.检查系统内存及交换区使用
$ top
8. 检查数据库的SGA设置
SQL> show sga
Total System Global Area 622299344 bytes
Fixed Size 731344 bytes
Variable Size 268435456 bytes
Database Buffers 352321536 bytes
Redo Buffers 811008 bytes
SQL>
对于RAM小于1G的系统,Dedicated模式下,Oracle的SGA一般不应超过1/2物理内存.
9.第一步调整
减小SGA,为系统保留足够的内存.
10.增加swap区
wapplatform:/var/swap>cd /export/home1
wapplatform:/export/home1>ls
TT_DB lost+found oracle oracli9
wapplatform:/export/home1>mkdir swap
wapplatform:/export/home1>cd swap
wapplatform:/export/home1/swap>mkfile -v 1g swapfile1
swapfile1 1073741824 bytes
wapplatform:/export/home1/swap>id
uid=0(root) gid=1(other)
wapplatform:/export/home1/swap>swap -a /export/home1/s

wap/swapfile1
wapplatform:/export/home1/swap>swap -s
11.连接测试
/export/home1/oracle>sqlplus "/ as sysdba"

问题总结:
Oracle数据库问题的解决从来就离不开操作系统.
很多时候我们必须通过操作系统一级的手段来诊断并解决问题.关于操作系统,一般Swap区的推荐值为2XRAM,如果Ram很大,不一定非要把Swap设置为2xRam,但是通常至少设置Swap = Ram,如果Swap区过小,在系统繁忙期间产生大量交换无法换到磁盘,就会出现问题.如本案例就是这样。另外,如果系统Ram较小,通常设置SGA < 1/2 Ram,要为Server process及OS保留足够的内存空间.

 

分享到:
评论

相关推荐

    关于SGA设置的一点总结

    仅对服务器只存在OS + ORACLE 为例,如果存在其他应用请酌情考虑 写这个也是因为近来这种重复性的问题发生的太多所导致的

    oracle sga设置

    ### Oracle SGA 设置详解 #### 一、Oracle SGA 概述 在Oracle数据库系统中,SGA(System Global Area)是所有用户进程共享的一块内存区域,它为Oracle实例提供了一个公共的数据和控制信息存储区。SGA的合理配置...

    oracle改sga导致数据库启动异常处理办法

    如果 SGA 参数设置不当,可能会导致数据库启动异常、性能下降或崩溃。 二、数据库启动异常的原因 当调整 SGA 参数后,数据库可能无法启动,出现异常。这是因为 SGA 参数的调整可能会导致数据库的内存分配错误,...

    sga调整过大oracle无法启动解决方案

    然而,如果 SGA 设置太大,可能会导致数据库无法启动。本文档记录了 LINUX 环境下将 ORACLE 的 SGA 设置过大导致数据库无法启动的解决方案。 问题描述: 在 32 位 WINDOWS SERVER 2003 旗舰版、16G 内存、ORACLE...

    RHEL4 32bit大SGA设置

    RHEL4下32bit oracle大SGA设置

    关于oracle sga设置的总结2012231143131796.txt

    oracle11g10g安装备份基础维护

    更改ORACLE SGA的详细步骤

    下面将详细介绍如何更改 Oracle SGA 的大小,以及在出现问题时如何恢复到初始设置。 1. **查询 SGA 参数**: 在命令行中,使用 `sqlplus` 登录到数据库,以 `sysdba` 角色连接: ``` sqlplus /nolog Conn / as ...

    Oracle 9i 调整SGA性能

    合理设置UNDO表空间大小可以避免空间不足导致的性能问题。 进行SGA性能调整时,你需要关注以下几点: 1. 性能监控:使用Oracle的性能分析工具如V$视图,监控SGA各个组件的使用情况,如DB BUFFER CACHE HIT RATIO、...

    PGA,SGA与内存

    通过这些视图,可以获取到关于PGA和SGA的详细信息,如当前使用的大小、已分配的最大值、剩余可分配的内存等,从而帮助管理员更好地理解和优化数据库的内存使用。 总之,合理配置和监控PGA与SGA的大小对于保证Oracle...

    Oracle_SGA

    - **自动内存管理(Automatic Shared Memory Management, ASMM)**:如果设置了`SGA_TARGET`参数为非零值,则会启用ASMM。这允许Oracle根据内存需求自动调整SGA中自动管理的组件大小。 - **启用条件**:要启用ASMM,...

    oracle-sga结构

    对SGA的监控和管理是数据库管理员的重要任务,合理设置各个区域的大小,可以有效提升数据库性能,减少不必要的系统开销。监控SGA的使用情况,适时调整参数,有助于确保系统的稳定性和高效运行。同时,了解SGA的工作...

    ORACLE 内存调整(SGA和PGA)

    SGA+PGA最好不要超过总内存的70%,内存详细调整方案,供学习。

    linuxVM平台扩展SGA

    这可以通过设置 `hugepagesz` 和 `hugepages` 参数来实现。 **用途**: 适用于需要大量连续内存的应用程序,如 Oracle 数据库实例。 #### 合法组合 为了确保系统稳定运行并充分发挥硬件潜力,必须合理配置各项参数...

    WINDOWS平台上扩展SGA

    在 Windows 操作系统上运行 Oracle 数据库时,可能会遇到关于 SGA(共享全局区)大小的限制问题。特别是在早期版本的 32 位 Windows 操作系统中,由于地址空间的限制,Oracle 数据库在 SGA 大小方面受到了一定的约束...

    oracle Sga调优

    3. **调整参数设置**:根据监控结果调整SGA各部分的大小和比例。 #### 四、具体调优步骤 1. **确定当前SGA配置**:首先查看当前的SGA配置情况,可以通过执行如下SQL命令获得相关信息: ```sql SELECT name, value...

    32位Windows上使用超过1.7GB SGA的方法

    当尝试将SGA设置得高于1.7GB时,Oracle会抛出ORA-27102(out of memory)错误。然而,在某些场景下,为了提高数据库性能,可能需要突破这一限制。 #### 技术实现方法 要使32位Windows系统支持超过1.7GB的SGA,需要...

    修改oracle初始化参数,包括Process,Session,SGA,PGA

    这里我们将`SGA`目标大小设置为8GB,`PGA`目标大小设置为2GB。同样地,这些更改是持久化的,需要重启数据库才能生效。 ```sql SQL&gt; create pfile from spfile; SQL&gt; shutdown immediate; SQL&gt; startup; ``` #### 小...

Global site tag (gtag.js) - Google Analytics