网站大量收购独家精品文档,联系QQ:2885784924

[计算机]Oracle数据库提高命中率及相关优化.doc

[计算机]Oracle数据库提高命中率及相关优化.doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

qiwqpu54 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档