注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

常在心

淡泊明志,人生自在

 
 
 

日志

 
 

动态性能视图-v$sesstat  

2011-03-28 13:52:23|  分类: 常用动态性能视图 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

学习动态性能表
第二篇-(1)-v$sesstat  2007.5.25 转三思笔记

  按照OracleOnlineBook中的描述,v$sesstat存储session从login到logout的详细资源使用统计。

  类似于v$sysstat,该视图存储下列类别的统计:

? 事件发生次数的统计,? 如用户提交数。
? 数据产生,? 存取或者操作的total列(如:redo size)
? 执行操作所花费的时间累积,? 例如session CPU占用(如果TIMED_STATISTICS值为true)
注意:
如果初始参数STATISTICS_LEVEL被设置为TYPICAL或ALL,时间统计被数据库自动收集如果STATISTICS_LEVEL被设置为BASIC,你必须设置TIMED_STATISTICS值为TRUE以打开收集功能。

如果你已设置了DB_CACHE_ADVICE,TIMED_STATISTICS或TIMED_OS_STATISTICS,或在初始参数文件或使用ALTER_SYSTEM或ALTER SESSION,那么你所设定的值的值将覆盖STATISTICS_LEVEL的值。

v$sysstat和v$sesstat差别如下:
? v$sesstat只保存session数据,而? v$sysstat则保存所有sessions的累积值。
? v$sesstat只是暂存数据,? session退出后数据即清空。v$sysstat则是累积的,? 只有当实例被shutdown才会清空。
? v$sesstat不? 包括统计项名? 称,? 如果要获得统计项名? 称则必须与v$sysstat或v$statname连接查询获得。

v$sesstat可被用于找出如下类型session:
? 高资源占用
? 高平均资源占用比(登陆后资源使用率)
? 默认资源占用比(两快照之间)

在V$SESSTAT中使用统计
  多数v$sesstat中的统计参考是v$sysstat描述的子集,包括session logical reads, CPU used by this session, db block changes, redo size, physical writes, parse count (hard), parse count (total), sorts (memory), and sorts (disk).

V$SESSTAT常用列说明
? SID:session唯一ID
? STATISTIC#:资源唯一ID
? VALUE:资源使用


示例1:下列找出当前session中最高的logical和Physical I/O比率.

  下列SQL语句显示了所有连接到数据库的session逻辑、物理读比率(每秒)。logical和physical I/O比率是通过自登陆后的时间消耗计算得出。对于sessions连接到数据库这种长周期操作而言也许不够精确,不过做个示例却足够了。

先获得session逻辑读和物理读统计项的STATISTIC#值:
SELECT name, statistic#
  FROM V$STATNAME
  WHERE name IN ('session logical reads','physical reads') ;
NAME                           STATISTIC#
------------------------------ ----------
session logical reads                   9
physical reads                         40

通过上面获得的STATISTIC#值执行下列语句:

SELECT ses.sid
     , DECODE(ses.action,NULL,'online','batch')          "User"
     , MAX(DECODE(sta.statistic#,9,sta.value,0))
       /greatest(3600*24*(sysdate-ses.logon_time),1)     "Log IO/s"
     , MAX(DECODE(sta.statistic#,40,sta.value,0))
       /greatest(3600*24*(sysdate-ses.logon_time),1)     "Phy IO/s"
     , 60*24*(sysdate-ses.logon_time)                    "Minutes"
 FROM V$SESSION ses
    , V$SESSTAT sta
WHERE ses.status     = 'ACTIVE'
  AND sta.sid        = ses.sid
  AND sta.statistic# IN (9,40)
GROUP BY ses.sid, ses.action, ses.logon_time
ORDER BY
        SUM( DECODE(sta.statistic#,40,100*sta.value,sta.value) )
      / greatest(3600*24*(sysdate-ses.logon_time),1)  DESC;

  SID User   Log IO/s Phy IO/s Minutes
----- ------ -------- -------- -------
 1951 batch       291    257.3       1
  470 online    6,161     62.9       0
  730 batch     7,568     43.2     197
 2153 online    1,482     98.9      10
 2386 batch     7,620     35.6      35
 1815 batch     7,503     35.5      26
 1965 online    4,879     42.9      19
 1668 online    4,318     44.5       1
 1142 online      955     69.2      35
 1855 batch       573     70.5       8
 1971 online    1,138     56.6       1
 1323 online    3,263     32.4       5
 1479 batch     2,857     35.1       3
  421 online    1,322     46.8      15
 2405 online      258     50.4       8


示例2:又例如通过v$sesstat和v$statname连接查询某个SID各项信息。
select a.*,b.name
  from v$sesstat a,v$statname b
  where a.sid=10 and a.statistic#=b.statistic#;


第二篇-(2)-v$mystat  2007.6.8

  本视图是v$sesstat的一个子集,返回当前session的统计项。当通过触发器审计session资源使用,可以使用v$mystat来捕获资源使用,这将比直接扫描v$sesstat的列要节省资源的多。


 

  评论这张
 
阅读(107)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017