- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[计算机]Oracle数据库提高命中率及相关优化
Oracle数据库提高命中率及相关优化
2010-01-29 09:41 蓝色天空 CHINAUNIX 我要评论(0) 字号:T | T
本文将为大家介绍在Oracle数据库中,如何提高命中率,以及相关算法的性能对比。希望这些比较过程能帮助大家更高效率的管理Oracle。
AD:
本文是关于Oracle数据库调试与优化方面的文章,主要介绍Oracle数据库中命中率相关的问题,包括不同的算法之间性能的比对。51CTO编辑向您推荐《Oracle数据库调试与性能优化》
关于Oracle中各个命中率的计算以及相关的调优
1)Library Cache的命中率:
.计算公式:Library Cache Hit Ratio = sum(pinhits) / sum(pins)
SQLSELECT?SUM(pinhits)/sum(pins)?? ?
FROM?V$LIBRARYCACHE;?
通常在98%以上,否则,需要要考虑加大共享池,绑定变量,修改cursor_sharing等参数。
2)计算共享池内存使用率:
SQLSELECT?(1?-?ROUND(BYTES?/?(TSP_IN_M?*?1024?*?1024),?2))?*?100?||?%?
FROM?V$SGASTAT ?
WHERE?NAME?=?free?memory?AND?POOL?=?shared?pool;?
其中: TSP_IN_M是你的总的共享池的SIZE(M)
共享池内存使用率,应该稳定在75%-90%间,太小浪费内存,太大则内存不足。
查询空闲的共享池内存:
SQLSELECT?*?FROM?V$SGASTAT ?
WHERE?NAME?=?free?memory?AND?POOL?=?shared?pool;?
3)db buffer cache命中率:
计算公式:Hit ratio = 1 - [physical reads/(block gets + consistent gets)]
SQLSELECT?NAME,?PHYSICAL_READS,?DB_BLOCK_GETS,?CONSISTENT_GETS, ?
1?-?(PHYSICAL_READS?/?(DB_BLOCK_GETS?+?CONSISTENT_GETS))?Hit?Ratio?
FROM?V$BUFFER_POOL_STATISTICS ?
WHERE?NAME=DEFAULT;?
通常应在90%以上,否则,需要调整,加大DB_CACHE_SIZE
另外一种计算命中率的方法(摘自ORACLE官方文档数据库性能优化):
命中率的计算公式为:
Hit?Ratio?=?1?-?((physical?reads?-?physical?reads?direct?-?physical?reads?direct?(lob))?/?(db?block?gets?+?
consistent?gets?-?physical?reads?direct?-?physical?reads?direct?(lob))?
分别代入上一查询中的结果值,就得出了Buffer cache的命中率
SQLSELECT?NAME,?VALUE ?
FROM?V$SYSSTAT ?
WHERE?NAME?IN(session?logical?reads, ?
physical?reads, ?
physical?reads?direct, ?
physical?reads?direct?(lob), ?
db?block?gets,?consistent?gets);?
4)数据缓冲区命中率:
SQL?select?value?from?v$sysstat?where?name?=physical?reads; ?
SQL?select?value?from?v$sysstat?where?name?=physical?reads?direct; ?
SQL?select?value?from?v$sysstat?where?name?=physical?reads?direct?(lob); ?
SQL?select?value?from?v$sysstat?where?name?=consistent?gets; ?
SQL?select?value?from?v$sysstat?where?name?=?db?block?gets;?
这里命中率的计算应该是
令 x = physical reads direct + physical reads direct (lob)
命中率 =100 - ( physical reads - x) / (consistent gets + db block gets
文档评论(0)