当前位置:  数据库>oracle

使用Statspack进行Oracle性能分析

    来源: 互联网  发布时间:2017-04-19

    本文导语: 做运行报告的时候,主机可以取CPU,内存,进程数的相关参数做报表,而数据库却很难做出长时间性能参数的报告。Statspack是Oracle性能分析的一个报告,但这个报告只能取一个规定时间段的值,可以用来分析问题,但不能反映随...

做运行报告的时候,主机可以取CPU内存进程数的相关参数报表,而数据库却很难做出长时间性能参数的报告。StatspackOracle性能分析的一个报告,但这个报告只能取一个规定时间段的值,可以用来分析问题,但不能反映随时间的变化趋势,也很难进行图表展示。

Oracle相关工具toad提供了statspack的简单图表展示,但选择时间点很麻烦,且只有有限几个参数。原则上来说,工具能实现的功能利用sql语句都能实现。下面是一个利用statspack进行oracle性能分析的一个简单例子。

具体sql语句如下

select w.snap_id,
       sn.SNAP_TIME,
       w.event event,
       w.total_waits - w.last_wait waits,
       w.total_timeouts - w.last_timeout timeouts,
       (w.time_waited - w.last_time_waited)/




1000000 time_waited_S
from  perfstat.stats$snapshot sn,
      (select snap_id, dbid, instance_number, event,
              total_waits,
              lag(total_waits,



1) over (order by event, snap_id) last_wait,
              total_timeouts,
              lag(total_timeouts,

1) over (order by event, snap_id) last_timeout,              time_waited_micro time_waited,
              lag(time_waited_micro,
1) over (order by event, snap_id)
last_time_waited       from perfstat.stats$system_event
       where    event not in (select event from perfstat.stats$IDLE_EVENT)
       and    snap_id in (select snap_id from stats$snapshot where snap_time >sysdate -


300) ----300 days
       ) w
where w.time_waited - w.last_time_waited >

0
and   w.snap_id > (select min(snap_id) from stats$snapshot where snap_time >sysdate -
300)  ----300 days
--and   SN.snap_id in (22391,22392,22393)
and   sn.snap_id = w.snap_id
and   sn.dbid = w.dbid
and   sn.instance_number = w.instance_number
and   event not like



'%message%'
and   event not like
'SQL*Net%'
and   (w.time_waited - w.last_time_waited) >
600*1000000 ---- wait time >10 min
UNION ALL
select
   ss.snap_id, sn.SNAP_TIME,
'CPU TIME' ,0, 0,ROUND((ss.value - lag(ss.value,1) over (order by ss.snap_id))/100,0) as value_cputime
from     perfstat.stats$sysstat ss, perfstat.stats$snapshot sn
where    ss.snap_id = sn.snap_id
and      ss.name =


'CPU used by this session'
and ss.snap_id in (select snap_id from stats$snapshot where snap_time >sysdate -
300)
--and ss.snap_id in (22391,22392,22393)
and ss.dbid = sn.dbid
and ss.instance_number = sn.instance_number
order by


1, 6 desc


通过sql查询出来的数据,导入到excel中(可以利用taod、pl/sql等工具),利用excel的透视图功能,进行图形绘制,如下图是某系统2011年1月的top wait event的结果。从图可以看出主要等待事件db file sequential read和cpu time。db file sequentialread事件多说明系统IO压力大。

使用Statspack进行Oracle性能分析[图片]

命中率的(本周),低点一般在凌晨4点,其它命中率98%以上

理论上讲,statspack报告中的所有性能参数都可以进行图表展示,前提是拥有定期收集的数据。


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux系统下使用使用性能监视工具的前提?
  • 性能测试中应该用top命令统计cpu使用情况还是ps命令?
  • 请教各位:只安装TOMCAT而不搭配apache一起使用,在性能上有什么差别
  • ********************使用io复用好还是多线程的性能好?**************************
  • 强制SQL Server执行计划使用并行提升在复杂查询语句下的性能
  • oracle 使用递归的性能提示测试对比
  • 使用sqlbulkcopy提高导入数据的性能的方法
  • 【求助贴】数据库基准性能测试OSDL以及其工具的BDT系列的使用
  • mysql性能优化脚本mysqltuner.pl使用介绍
  • 在Python中使用异步Socket编程性能测试
  • 在Nginx中使用X-Sendfile头提升PHP文件下载的性能(针对大文件下载)
  • 如何书写高质量jQuery代码(使用jquery性能问题)
  • MySQL索引背后的之使用策略及优化(高性能索引策略)
  • C++ I/O 成员 tellg():使用输入流读取流指针
  • 在测试memset函数的执行效率时,分为使用Cash和不使用Cash辆种方式,该如何控制是否使用缓存?
  • C++ I/O 成员 tellp():使用输出流读取流指针
  • 求ibm6000的中文使用手册 !从来没用过服务器,现在急需使用它,不知如何使用! 急!!!!!
  • Python不使用print而直接输出二进制字符串
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • Office 2010 Module模式下使用VBA Addressof
  • 急求结果!!假设一个有两个元素的信号量集S,表示了一个磁带驱动器系统,其中进程1使用磁带机A,进程2同时使用磁带机A和B,进程3使用磁带机B。
  • windows下tinyxml.dll下载安装使用(c++解析XML库)
  • c#中SAPI使用总结——SpVoice的使用方法
  • tcmalloc内存泄露优化c++开源库下载,安装及使用介绍
  • 使用了QWidget的程序,如何使用后台程序启动它?
  • sharepoint 2010 使用STSNavigate函数实现文件下载举例
  • 共享内存一般是怎么使用的,是同消息队列配合使用么
  • 使用libpcap读取tcpdump抓取的文件并解析c代码实例
  • Jsp可否使用带有GUI的JavaBean,如何使用?
  • c/c++预处理命令预#,##使用介绍
  • asp程序使用的access在Linux下如何使用!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3