Oracle 检查命中率的 SQL

PHPABC Oracle 1,056 次浏览 , , 3条评论

在数据库启动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%为最佳
2.数据字典缓存命中率:
数据字典缓存命中率显示了对数据字典和其他对象的内存读操作所占的百分比。

SELECT (1-(SUM(getmisses)/SUM(gets))) * 100 "Hit Ratio" FROM v$rowcache;

大于98%为最佳

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

SELECT SUM(Pins)/(SUM(Pins) + SUM(Reloads)) * 100 "Hit Ratio" FROM V$LibraryCache;

大于98%为最佳
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)';

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);

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%为最佳。
7.调整滥用磁盘读操作的主要语句

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

SELECT disk_reads, substr(sql_text,1,4000) FROM v$sqlarea  ORDER BY disk_reads DESC;

8.表和与它们相关联的索引应当放置在不同的物理磁盘上,以便减少文件I/O。

以上测试也可以通过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)

3条评论

  1. hie 2010年6月26日 16:59 回复

    学习了!谢谢分享!

  2. aka-jack 2010年6月26日 14:04 回复

    不错的站点,有空来看看!

  3. 2010年6月20日 22:14 回复

    恩。。。不错不错。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据

Go