(轉):學習Oracle動態效能表-(5)-V$SESSTAT

xz43發表於2010-11-16
按照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比率.

  下列語句顯示了所有連線到資料庫的session邏輯、物理讀比率(每秒)logicalphysical I/O比率是透過自登陸後的時間消耗計算得出。對於sessions連線到資料庫這種長週期操作而言也許不夠精確,不過做個示例卻足夠了。

先獲得session邏輯讀和物理讀統計項的STATISTIC#值:

SELECTname, statistic#

FROMV$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各項資訊。

selecta.*,b.name

fromv$sesstat a,v$statname b

wherea.sid=10anda.statistic#=b.statistic#;

(2)-v$mystat

  本檢視是v$sesstat的一個子集,返回當前session的統計項。當透過觸發器審計session資源使用,可以使用v$mystat來捕獲資源使用,這將比直接掃描v$sesstat的列要節省資源的多。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9399028/viewspace-678253/,如需轉載,請註明出處,否則將追究法律責任。

相關文章