日期:2014-05-16  浏览次数:20304 次

一些关于oracle SGA 优化的技巧

一、SGA

1Shared pool tunning

Shared pool的优化应该放在优先考虑,因为一个cache missshared pool中发生比在data buffer中发生导致的成本更高,由于dictionary数据一般比library cache中的数据在内存中保存的时间长,所以关键是library cache的优化。

Gets:(parse)在namespace中查找对象的次数;

Pins:(execution)在namespace中读取或执行对象的次数;

Reloads(reparse)在执行阶段library cache misses的次数,导致sql需要重新解析。

1) 检查v$librarycachesql areagethitratio是否超过90%,如果未超过90%,应该检查应用代码,提高应用代码的效率。

Select gethitratio from v$librarycache where namespace=’sql area’;

?

2) v$librarycachereloads/pins的比率应该小于1%,如果大于1%,应该增加参数shared_pool_size的值。

Select sum(pins) “executions”,sum(reloads) “cache misses”,sum(reloads)/sum(pins) from v$librarycache;

?

reloads/pins>1%有两种可能,一种是library cache空间不足,一种是sql中引用的对象不合法。

?

3shared pool reserved size一般是shared pool size的<