ORACLE sid,pid,spid總結

概念上:
1.spid (system process id)  是操作系統層面的進程id .
2.pid(process id)  這個是基於oracle的進程id個人理解爲就是oracle給自己的進程的一個編號。
3.sid.(這個就是session 的id) 這個個人理解爲,就是有人在同oracle連接會話,oracle爲其分配的一個編號。長用於連接其他列。

說道這還的和幾個動態性能視圖聯繫起來。
1.v$process視圖  
此視圖包含當前系統中oracle的所有的進程信息,常被用於將oracle或服務進程的操作系統進程ID與數據庫session之間建立聯繫。
常用列:
         ADDR:進程對象地址
         PID:oracle進程ID
         SPID:操作系統進程ID
         V$PROCESS中的連接列 ADDR 通常與V$SESSION PADDR相連接。
如:select p.addr,P.PID,P.PID, s.paddr from v$process p,v$session s
where P.ADDR=S.PADDR
2.v$session視圖
         V$SESSION是基礎信息視圖,用於找尋用戶SID或SADDR。不過,它也有一些列會動態的變化,可用於檢查用戶。
常用列:
         SID:SESSION標識,常用於連接其它列。
         SERIAL#:如果某個SID又被其它的session使用的話則此數值自增加(當一個SESSION結束,另一個SESSION開始並使用了同一個SID)。
         AUDSID:審查session ID唯一性,確認它通常也用於當尋找並行查詢模式
         USERNAME:當前session在oracle中的用戶名。
         STATUS:這列用來判斷session狀態是:
         Achtive:正執行SQL語句(waiting for/using a resource)
         Inactive:等待操作(即等待需要執行的SQL語句)
         Killed:被標註爲刪除
         paddr, process addr, 通過這個字段我們可以查看當前進程的相關信息, 系統進程id,操作系統用戶信息等等.
         (sql_address,sql_hash_value) (prev_sql_addr,prev_hash_value) 根據這兩組字段, 我們可以查詢到當前session正在執行的sql語句的詳細
3.v$sqltext視圖
        此視圖包括共享池(share poll)中sql語句的完整文本,一條sql語句可能被分成多個快被保存。
常用列:
         HASH_VALUE:SQL語句的Hash值
         ADDRESS:sql語句在SGA中的地址
         SQL_TEXT:SQL文本。
         PIECE:SQL語句塊的序號
V$SQLTEXT中的連接列
Column                                 View                             Joined Column(s)
HASH_VALUE, ADDRESS                  V$SQL, V$SESSION          HASH_VALUE, ADDRESS
HASH_VALUE. ADDRESS                  V$SESSION                   SQL_HASH_VALUE, SQL_ADDRESS
按pid查看正在執行的程序:
         select sid,program from v$session b where paddr in (select addr from v$process where spid=$pid);
按pid查看正在執行的sql語句
         select sql_text from v$sqltext where hash_value in (select sql_hash_value from v$session where   
         PADDR in (select addr from v"$process where spid=$pid)) order by piece;
4.V$SESSION_WAIT視圖
         這是一個尋找性能瓶頸的關鍵視圖。它提供了任何情況下session在數據庫中當前正在等待什麼(如果session當前什麼也沒在做,則顯示它最後的等待事件)。當系統存在性能問題時,本視圖可以做爲一個起點指明探尋問題的方向。
         V$SESSION_WAIT中,每一個連接到實例的session都對應一條記錄。
常用列:
         SID: session標識
         EVENT: session當前等待的事件,或者最後一次等待事件。
         WAIT_TIME: session等待事件的時間(單位,百分之一秒)如果本列爲0,說明session當前session還未有任何等待。
         SEQ#: session等待事件將觸發其值自增長
         P1, P2, P3: 等待事件中等待的詳細資料
         P1TEXT, P2TEXT, P3TEXT: 解釋說明p1,p2,p3事件
附註:
         1.State字段有四種含義:
         Waiting:SESSION正等待這個事件。
         Waited unknown time:由於設置了timed_statistics值爲false,導致不能得到時間信息。表示發生了等待,但時間
很短
         Wait short time:表示發生了等待,但由於時間非常短不超過一個時間單位,所以沒有記錄。
         Waited knnow time:如果session等待然後得到了所需資源,那麼將從waiting進入本狀態。
         Wait_time值也有四種含義:
值>0:最後一次等待時間(單位:10ms),當前未在等待狀態。
         值=0:session正在等待當前的事件。
         值=-1:最後一次等待時間小於1個統計單位,當前未在等待狀態。
         值=-2:時間統計狀態未置爲可用,當前未在等待狀態。
3.Wait_time和Second_in_wait字段值與state相關:
         如果state值爲Waiting,那麼wait_time值無用。Second_in_wait值是實際的等待時間(單位:秒)。
         如果state值爲Wait unknow time,那麼wait_time值和Second_in_wait值都無用。
         如果state值爲Wait short time,那麼wait_time值和Second_in_wait值都無用。
         如果state值爲Waiting known time,那麼wait_time值就是實際等待時間(單位:秒),Second_in_wait值無用。
V$SESSION_WAIT中的連接列
Column View Joined Colum
SID V$SESSION SID
查看session等待事件:
         select sid,event from v$session_wait where event not like ’rdbms%’ and event not like ’SQL*Net message%’;
         多數的session都是空閒事件如:SQL*Net message from client, pipe get, PMON timer等


原文地址:http://blog.itpub.net/21416913/viewspace-743930

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章