[Oracle]セッションIDとOSPIDを紐づける方法

Oracle

Oracle DBのv$sessionで出力される情報はSID(セッションID)をベースとしてます。ただし、各プロセスのCPU使用率を追いたい場合には、SIDとOSPIDを紐づける必要があります。

SIDとOSPIDの紐づけ

以下のSQLで紐づけられます。v$procesのSPID列がOSPIDに相当します。

select sid, pid, spid, s.username, osuser, s.program 
from v$process p, v$session s 
where p.addr=s.paddr;

実行結果はこちらです。

 SID PID SPID  USERNAME OSUSER   PROGRAM
---- --- ----- -------- -------- -------------------------------
   2   2 5537           ora11204 oracle@ol66.local (PMON) ★
   3   3 5539           ora11204 oracle@ol66.local (PSP0)
   4   4 5541           ora11204 oracle@ol66.local (VKTM)
   5   5 5545           ora11204 oracle@ol66.local (GEN0)
   6   6 5547           ora11204 oracle@ol66.local (DIAG)
   :

念のため正しいことをpsコマンドで確認してみます。上記のSPID=5537のプロセスは、OSから見たpid=5537に該当することが分かります。

$ ps -ef | grep 5537 | grep -v grep
ora11204  5537     1  0 00:01 ?        00:00:05 ora_pmon_orcl

セッションIDの確認

現在接続しているセッションのSIDを確認した場合は以下で可能です。

select distinct sid from v$mystat;
       SID
----------
        50

systemstateからの確認

取得する機会は少ないかもしれませんが、systemstate(情報取得した時点での全てのセッション情報をトレースファイルに出力できます。ただし、各セッションの情報は順次取得されていきますので、情報取得した時点から取得が完了するまでにタイムラグがあり、必ず同じ断面を取得できるとは限りませんのでご注意を)を取得することでもSIDとOSPIDを紐づけることができます。ハングやスピン系の障害だと役に立ちます。

systemstateの取得方法

SQL> alter session set events 'immediate trace name systemstate level 266';

トレースファイルが取得されるのでその内容を見てみます。

  :
PROCESS 2: PMON
  ----------------------------------------
  SO: 0x784a6868, type: 2, owner: (nil), flag: INIT/-/-/0x00 if: 0x3 c: 0x3
   proc=0x784a6868, name=process, file=ksu.h LINE:12721, pg=0
  (process) Oracle pid:2, ser:1, calls cur/top: 0x780c5818/0x780c5818
            flags : (0xe) SYSTEM
            flags2: (0x0),  flags3: (0x10)
            intr error: 0, call error: 0, sess error: 0, txn error 0
            intr queue: empty
    ksudlp FALSE at location: 0
  (post info) last post received: 0 0 281
              last post received-location: kmmcts.h LINE:2898 ID:kmmreg()
              last process to post me: 0x784b84a0 53 2
              last post sent: 0 0 26
              last post sent-location: ksa2.h LINE:285 ID:ksasnd
              last process posted by me: 0x784a7920 1 6
    (latch info) wait_event=0 bits=0x0
    Process Group: DEFAULT, pseudo proc: 0x7854deb0
    O/S info: user: ora11204, term: UNKNOWN, ospid: 5537 <--★ OSPID=5537
    OSD pid info: Unix process pid: 5537, image: oracle@ol66.local (PMON)
  :
    SO: 0x78080600, type: 4, owner: 0x784a6868, flag: INIT/-/-/0x00 if: 0x3 c: 0x3
     proc=0x784a6868, name=session, file=ksu.h LINE:12729, pg=0
    (session) sid: 2 ser: 1 trans: (nil), creator: 0x784a6868 <--★ SID=2
              flags: (0x51) USR/- flags_idl: (0x1) BSY/-/-/-/-/-
              flags2: (0x409) -/-/INC
              DID: 0002-, short-term DID:
              txn branch: (nil)
              edition#: 0              oct: 0, prv: 0, sql: (nil), psql: (nil), user: 0/SYS
    ksuxds FALSE at location: 0
    service name: SYS$BACKGROUND
  :

「ospid: 5537」と出力されている部分が、OS上で確認できるPIDに相当します。この内容からセッションIDとOSPIDを紐づけることができます。

コメント

タイトルとURLをコピーしました