干货分享|七个 Oracle 检查命中率命中的常见SQL

干货分享|七个 Oracle 检查命中率命中的常见SQL概述日常工作中,在数据库启动2小时后,可以通过以下SQL来测试数据库性能1. 缓冲区命中率:缓冲区命中率表示在不需要进行磁盘访问的情况下在内存结

大家好,欢迎来到IT知识分享网。

概述

日常工作中,在数据库启动2小时后,可以通过以下SQL来测试数据库性能

1. 缓冲区命中率:

缓冲区命中率表示在不需要进行磁盘访问的情况下在内存结构中找到常用数据块的频率

select (1-(sum(decode(name, ‘physical reads’,value,0))/(sum(decode(name, ‘db block gets’,value,0))

+sum(decode(name,’consistent gets’,value,0))))) * 100 “Hit Ratio”

from v$sysstat;

大于98%为最佳

干货分享|七个 Oracle 检查命中率命中的常见SQL

2.数据字典缓存命中率:

数据字典缓存命中率显示了对数据字典和其他对象的内存读操作所占的百分比。

select (1-(sum(getmisses)/sum(gets))) * 100 “Hit Ratio” from v$rowcache;

大于98%为最佳

干货分享|七个 Oracle 检查命中率命中的常见SQL

3.库缓存命中率:

库缓存命中率显示了对实际语句和PL/SQL对象的内存读操作所占的百分比。注意,很高的命中率并不总是一件好事。

select Sum(Pins)/(Sum(Pins) + Sum(Reloads)) * 100 “Hit Ratio” from V$LibraryCache;

大于98%为最佳

干货分享|七个 Oracle 检查命中率命中的常见SQL

4.PGA内存排序命中率

自动PGA内存管理简化了分配PGA内存的方法。Oracle动态调整工作区PGA内存的大小(以SGA内存大小的20%为基础)。在自动PGA内存管理模式下运行时,所有会话的工作区大小都是自动的。实例中活动工作区可用的PGA内存总量自动由SORT_AREA_SIZE或PGA _ AGGREGATE_ TARGET(首选)初始化参数导出。PGA内存排序率的值应该大于98%。依据初始化参数PGA_AGGREGATE_TARGET(或者用于向后兼容的SORT _AREA _ SIZE)的值,用户排序可能在内存或者在指定的临时表空间中的磁盘上完成,如果这个初始化参数不是太高的话。

select a.value “Disk Sorts”, b.value “Memory Sorts”,round((100*b.value)/decode((a.value+b.value),0,1,(a.value+b.value)),2)”Pct Memory Sorts” from v$sysstat a, v$sysstat b where a.name = ‘sorts (disk)’and b.name = ‘sorts (memory)’;

干货分享|七个 Oracle 检查命中率命中的常见SQL

5. 空闲的数据缓冲区的比例

从首次启动Oracle数据库的那一天开始,用户们的查询就开始使用内存。空闲的记录数除以X$BH表中的记录总数(即所分配的数据块缓冲区的总数)就得到这个百分比。同时请注意,必须以SYS的权限来运行该查询。此外,拥有众多的空闲缓冲区并不一定是就最佳环境。5%-10% 为最佳。当空闲比例高于25%时,数据缓冲区设置得太大了,可能会浪费资源。

select decode(state,0, ‘FREE’,1,decode(lrba_seq,0,’AVAILABLE’,’BEING USED’),3, ‘BEING USED’, state) “BLOCK STATUS”,count(*) from x$bh group by decode(state,0,’FREE’,1,decode(lrba_seq,0,’AVAILABLE’,’BEING USED’),3, ‘BEING USED’, state);

干货分享|七个 Oracle 检查命中率命中的常见SQL

6. 最浪费内存的前10个语句占所有语句的比例

在没有调整的情况下,大多数系统中10个最常使用的SQL语句的访问量占了整个系统中内存读操作的50%以上。本节测量了最影响性能的代码对整个系统所造成危害的严重性,以百分比表示。

select sum(pct_bufgets) “Percent” from (select rank() over ( order by buffer_gets desc ) as rank_bufgets,to_char(100 * ratio_to_report(buffer_gets) over (),’999.99′) pct_bufgets from v$sqlarea ) where rank_bufgets < 11;

小于5%为最佳。

干货分享|七个 Oracle 检查命中率命中的常见SQL

7.调整滥用磁盘读操作的主要语句

我发现在没有作调整的情况下,在绝大多数的系统中,访问量占前25位的语句的磁盘读操作将占用整个系统所有磁盘和/或内存读操作的75%。

select disk_reads, substr(sql_text,1,4000) from v$sqlarea order by disk_reads desc;

干货分享|七个 Oracle 检查命中率命中的常见SQL

以上测试也可以通过AWR和STATSPACK来查看. 在分析结果中,我们首先要看的十项内容:

1. 首要的5个等待时间(定时事件)

2. 负载简档(Load profile)

3. 实例效率点击率(Instance efficiency hit ratios)

4. 等待时间(Wait events)

5. 闩锁等待(Latch waits)

6. 首要的SQL(Top SQL)

7. 实例活动(Instance activity)

8. 文件I/0和段统计数据(File I/0 and segement statistics)

9. 内存分配(Memory allocation)

10.缓冲区等待(Buffer waits)


通过这些统计可以让我们更好的知道数据库的性能优化点,从而对应去优化调优。

后面会分享更多关于运维DBA方面的内容,感兴趣的朋友可以关注下~

干货分享|七个 Oracle 检查命中率命中的常见SQL

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/55471.html

(0)
上一篇 2024-07-21 22:15
下一篇 2024-07-26 13:26

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信