• 学习动态性能表 第二篇v$sesstat


     

    学习动态性能表

    第二篇--v$sesstat 

      按照OracleOnlineBook中的描述,v$sesstat存储sessionloginlogout的详细资源使用统计。

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

    l         事件发生次数的统计,如用户提交数。

    l         数据产生,存取或者操作的total(如:redo size)

    l         执行操作所花费的时间累积,例如session CPU占用(如果TIMED_STATISTICS值为true)

    注意:

    如果初始参数STATISTICS_LEVEL被设置为TYPICALALL,时间统计被数据库自动收集如果STATISTICS_LEVEL被设置为BASIC,你必须设置TIMED_STATISTICS值为TRUE以打开收集功能。

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

    v$sysstatv$sesstat差别如下:

    n         v$sesstat只保存session数据,而v$sysstat则保存所有sessions的累积值。

    n         v$sesstat只是暂存数据,session退出后数据即清空。v$sysstat则是累积的,只有当实例被shutdown才会清空。

    n         v$sesstat不包括统计项名称,如果要获得统计项名称则必须与v$sysstatv$statname连接查询获得。

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

    n         高资源占用

    n         高平均资源占用比(登陆后资源使用率)

    n         默认资源占用比(两快照之间)

    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常用列说明

    n         SIDsession唯一ID

    n         STATISTIC#:资源唯一ID

    n         VALUE:资源使用

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

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

    先获得session逻辑读和物理读统计项的STATISTIC#值:

    SELECTname, statistic#

     FROM V$STATNAME

     WHEREnameIN ('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$sesstatv$statname连接查询某个SID各项信息。

    select a.*,b.name

     from v$sesstat a,v$statname b

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

  • 相关阅读:
    JAVA假期第五天2020年7月10日
    JAVA假期第四天2020年7月9日
    JAVA假期第三天2020年7月8日
    JAVA假期第二天2020年7月7日
    JAVA假期第一天2020年7月6日
    CTF-sql-group by报错注入
    CTF-sql-order by盲注
    CTF-sql-sql约束注入
    CTF-sql-万能密码
    X-Forwarded-for漏洞解析
  • 原文地址:https://www.cnblogs.com/jimeper/p/1129432.html
Copyright © 2020-2023  润新知