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を紐づけることができます。
コメント