Orale数据库提高命中率及相关优化.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Orale数据库提高命中率及相关优化

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 - x)*100 通常如果发现命中率低于90%,则应该调整应用可可以考虑是否增大数据缓冲区 5)共享池的命中率: SQL?select?sum(pinhits-reloads)/sum(pins)*100?hit?radio?from?v$librarycache;? 假如共享池的命中率低于95%,就要考虑调整应用(通常是没使用bind var )或者增加内存 6)计算在内存中排序的比率: SQLSELECT?*?FROM?v$sysstat?t?WHERE?NAME=sorts?(memory);—查询内存排序数 ?

文档评论(0)

phltaotao + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档