学习动态性能表(2)--v$sesstat

学习动态性能表

第二篇--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的值。

 

vsysstatvsesstat差别如下:

  • vsesstatsessionvsysstat则保存所有sessions的累积值。
  • vsesstatsession退vsysstat则是累积的,只有当实例被shutdown才会清空。
  • vsesstatvsysstat或v$statname连接查询获得。

 

v$sesstat可被用于找出如下类型session:

  • 高资源占用
  • 高平均资源占用比(登陆后资源使用率)
  • 默认资源占用比(两快照之间)

 

在V$SESSTAT中使用统计

  多数vsesstatvsysstat描述的子集,包括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 vsesstata,vstatname b

  where a.sid=10 and a.statistic#=b.statistic#;

 

posted on   jack_Meng  阅读(734)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2014-03-12 C#对Jason序列化匿名对象
2014-03-12 C#对象的三种序列化
2014-03-12 BinaryFormatter、SoapFormatter、XML3种序列化
2014-03-12 NET怎么精确计算一个对象占用的内存空间(GMK)
2014-03-12 C# 能否获取一个对象所占内存的大小?

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏

主题色彩