Oracle性能优化经验分享之系统参数设置(装载)

本文分享了Oracle数据库性能优化的经验,重点介绍了系统参数设置的方法,包括shared pool的优化策略、buffer cache的调整技巧以及其他SGA对象的配置建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle性能优化经验分享之系统参数设置

SGAITPUB个人空间s9S-^
m
G/d7EKy

1
Shared pool tunning
3o k n,^1zy6~1PAy;e22934571Shared pool
的优化应该放在优先考虑,因为一个cache missshared pool中发生比在data buffer中发生导致的成本更高,由于dictionary数据一般比library cache中的数据在内存中保存的时间长,所以关键是library cache的优化。ITPUB个人空间'lN}}M XqcI
Gets
:(parse)在namespace中查找对象的次数;
4{{‑kBp22934571Pins
:(execution)在namespace中读取或执行对象的次数;ITPUB个人空间;~T;Hg.z
I b%m"u j

Reloads
(reparse)在执行阶段library cache misses的次数,导致sql需要重新解析。
f4ti4p6k*g229345711
检查v$librarycachesql areagethitratio是否超过90%,如果未超过90%,应该检查应用代码,提高应用代码的效率。
!|4H8X4R)T!t22934571Select gethitratio from v$librarycache where namespace=’sql area’;ITPUB
个人空间mU7S/q |/jl
2) v$librarycache
reloads/pins的比率应该小于1%,如果大于1%,应该增加参数shared_pool_size的值。ITPUB个人空间'`?8BI:O"{
Select sum(pins) “executions”,sum(reloads) “cache misses”,sum(reloads)/sum(pins) from v$librarycache;ITPUB
个人空间5Z v2Fm$sN4j-V,Pa
reloads/pins>1%
有两种可能,一种是library cache空间不足,一种是sql中引用的对象不合法。
U`i
H3e^229345713
shared pool reserved size一般是shared pool size10%,不能超过50%。V$shared_pool_reserved中的request misses0或没有持续增长,或者free_memory大于shared pool reserved size50%,表明shared pool reserved size过大,可以压缩。ITPUB个人空间 t@8K H:W*K!y‑n
4
)将大的匿名pl/sql代码块转换成小的匿名pl/sql代码块调用存储过程。
)[ i)fr&X229345715
)从9i开始,可以将execution plansql语句一起保存在library cache中,方便进行性能诊断。从v$sql_plan中可以看到execution plansITPUB个人空间&v0N7W u9‑uI2W/@
6
)保留大的对象在shared pool中。大的对象是造成内存碎片的主要原因,为了腾出空间许多小对象需要移出内存,从而影响了用户的性能。因此需要将一些常用的大的对象保留在shared pool中,下列对象需要保留在shared pool中:ITPUB个人空间]:[X8~(V‑S2Q-g/Y-uJ
a.
经常使用的存储过程;ITPUB个人空间0y G T#P4] x6D:F
b.
经常操作的表上的已编译的触发器
?0v8_5Z8UVS? Sk22934571c. Sequence
,因为Sequence移出shared pool后可能产生号码丢失。ITPUB个人空间P B x%iWK"I&Vf查找没有保存在library cache中的大对象:ITPUB个人空间"eY p|l(@)?
Select * from v$db_object_cache where sharable_mem>10000 and type in ('PACKAGE','PROCEDURE','FUNCTION','PACKAGE BODY') and kept='NO';ITPUB
个人空间n;uyCa%P将这些对象保存在library cache中:ITPUB个人空间(f&P#P5z[1]eI7jF
Execute dbms_shared_pool.keep(‘package_name’);
8_ gk!M*p22934571
对应脚本:dbmspool.sql
"GYo­bP9t 229345717)
查找是否存在过大的匿名pl/sql代码块。两种解决方案:ITPUB个人空间2y,~9kfk){OL
A
.转换成小的匿名块调用存储过程ITPUB个人空间 L B% X9i
B
.将其保留在shared poolITPUB个人空间(v7m X9sK"gQ
CU
查找是否存在过大的匿名pl/sql块:ITPUB个人空间3E;"s GPT%t&v q^*[
Select sql_text from v$sqlarea where command_type=47 and length(sql_text)>500;ITPUB
个人空间$M+v PYj y­j;h
8
Dictionary cache 优化ITPUB个人空间V.]!Zbb4c'b8Z }HB避免出现Dictionary cachemisses,或者misses的数量保持稳定,只能通过调整shared_pool_size来间接调整dictionary cache的大小。ITPUB个人空间Mr#X"k6aX
Percent misses
应该很低:大部分应该低于2%,合计应该低于15ITPUB个人空间!Z;N,HKu jq
Select sum(getmisses)/sum(gets) from v$rowcache;ITPUB
个人空间z"T)cMD'y9d若超过15%,增加shared_pool_size的值。





2Buffer Cache
0R z*lW,HM9TG_.]b229345711
granule大小的设置,db_cache_size以字节为单位定义了default buffer pool的大小。ITPUB个人空间5j:j0yR‑Z S如果SGA<128Mgranule=4M,否则granule16M,即需要调整sga的时候以granule为单位增加大小,并且sga的大小应该是granule的整数倍。
­hEp~ ~ O.GC ^;Z D229345712)
根据v$db_cache_advice调整buffer cache的大小ITPUB个人空间 wgnF4c
SELECT size_for_estimate,buffers_for_estimate,estd_physical_read_factor,estd_physical_reads FROM v$db_cache_advice WHERE NAME='DEFAULT' AND advice_status='ON' AND block_size=(SELECT Value FROM v$parameter WHERE NAME='db_block_size');
O6Bx[1]I)C_22934571estd_physical_read_factor<=1
UK1o'JB j229345713)
统计buffer cachecache hit ratio>90%,如果低于90%,可以用下列方案解决:ITPUB个人空间[1]S/vg:^$t5] Z(krX增加buffer cache的值;ITPUB个人空间 w Mk6J(_;S1U*q)T;K使用多个buffer pool
7W B ~#sPe R22934571Cache table

[1]q‑i|$dX x1`~22934571
sorting and parallel reads 建独立的buffer cache
8sH‑af6|"o 3|0H22934571SELECT NAME,value FROM v$sysstat WHERE NAME IN ('session logical reads','physical reads','physical reads direct','physical reads direct(lob)');
?3O%w_ ~2Ma22934571Cache hit ratio=1-(physical reads-physical reads direct-physical reads direct (lob))/session logical reads;ITPUB
个人空间
y‑}6T~ b n$f

Select 1-(phy.value-dir.value-lob.value)/log.value from v$sysstat log, v$sysstat phy, v$sysstat dir, v$sysstat LOB where log.name='session logical reads' and phy.name='physical reads' and dir.name='physical reads direct' and lob.name='physical reads direct (lob)';ITPUB
个人空间)Fo4X[1]@‑}$_9m+a:U0‑l影响cache hit ratio的因素:
g[1]M!qR}]2{22934571
全表扫描;应用设计;大表的随机访问;cache hits的不均衡分布ITPUB个人空间1V[.tF
4
)表空间使用自动空间管理,消除了自由空间列表的需求,可以减少数据库的竞争





3、其他SGA对象
.f.T'Oa2To7N j;q229345711
redo log bufferITPUB个人空间V Rp8`I4py对应的参数是log_buffer,缺省值与 OS相关,一般是500K。检查v$session_wait中是否存在log buffer wait,v$sysstat中是否存在

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22934571/viewspace-1047166/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22934571/viewspace-1047166/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值