一步一步教你學習如何玩轉跟蹤檔案
1.獲取跟蹤檔案路徑:
oracle資料庫獲取trace檔案方法:
10g
1.show parameter background_dump_dest
2.show parameter background_dump_dest
11
1.show parameter diag
2.select value from v$diag_info where name = 'Default Trace File';
10g和11g 通用
1.select name, value from v$parameter where name in ('user_dump_dest','background_dump_dest');
獲取當前trace檔案的指令碼:
select c.value || '/' || d.instance_name || '_ora_' ||
a.spid || '.trc' ||
case when e.value is not null then '_'||e.value end trace
from v$process a, v$session b, v$parameter c, v$instance d, v$parameter e
where a.addr = b.paddr
and b.audsid = userenv('sessionid')
and c.name = 'user_dump_dest'
and e.name = 'tracefile_identifier'
2.如何生成跟蹤檔案
2.1 跟蹤級別:
玩轉跟蹤不瞭解跟蹤級別是不行的,下面介紹Oracle可採用的跟蹤介面:
Level 0 = No statistics generated
Level 1 = standard trace output including parsing, executes and fetches plus more.
Level 2 = Same as level 1.
Level 4 = Same as level 1 but includes bind information
Level 8 = Same as level 1 but includes wait's information
Level 12 = Same as level 1 but includes binds and waits
2.2 跟蹤當前會話:
alter session set sql_trace=true;
執行相關sql
oracle資料庫獲取trace檔案方法:
10g
1.show parameter background_dump_dest
2.show parameter background_dump_dest
11
1.show parameter diag
2.select value from v$diag_info where name = 'Default Trace File';
10g和11g 通用
1.select name, value from v$parameter where name in ('user_dump_dest','background_dump_dest');
獲取當前trace檔案的指令碼:
select c.value || '/' || d.instance_name || '_ora_' ||
a.spid || '.trc' ||
case when e.value is not null then '_'||e.value end trace
from v$process a, v$session b, v$parameter c, v$instance d, v$parameter e
where a.addr = b.paddr
and b.audsid = userenv('sessionid')
and c.name = 'user_dump_dest'
and e.name = 'tracefile_identifier'
2.如何生成跟蹤檔案
2.1 跟蹤級別:
玩轉跟蹤不瞭解跟蹤級別是不行的,下面介紹Oracle可採用的跟蹤介面:
Level 0 = No statistics generated
Level 1 = standard trace output including parsing, executes and fetches plus more.
Level 2 = Same as level 1.
Level 4 = Same as level 1 but includes bind information
Level 8 = Same as level 1 but includes wait's information
Level 12 = Same as level 1 but includes binds and waits
2.2 跟蹤當前會話:
alter session set sql_trace=true;
執行相關sql
alter session set sql_trace=false;
alter session set events '10046 trace name context forever,level 1';
執行相關sql
alter session set events '10046 trace name context off';
2.3 獲取個人的sid,serail#
select sid, serial# from v$session where sid = (select sid from v$mystat where rownum=1);
獲取系統級別的會話:
select s.sid,s.serial#,s.username,s.osuser
from v$session s,v$process p
where s.paddr=p.addr;
3.使用oracledebug 跟蹤會話
3.1 使用ORADEBUG跟蹤當前會話
oradebug只能跟蹤SYS使用者的當前SESSION,如下方式:
sys@MAA> oradebug setmypid
sys@MAA> oradebug unlimit
sys@MAA> oradebug event 10046 trace name context forever, level 12
sys@MAA> exec our code
sys@MAA> oradebug event 10046 trace name context off
sys@MAA> oradebug tracefile_name
/u01/app/oracle/diag/rdbms/maa/maa/trace/maa_ora_17641.trc
3.2 使用ORADEBUG跟蹤其他會話
透過oradebug非常方便地跟蹤其他會話,如下方式:
luocs@MAA> select pid, spid from v$process p, v$session s where p.addr = s.paddr and s.sid=(select sid from v$mystat where rownum=1);
PID SPID
---------- ------------------------------------------------
25 17678
指定跟蹤SESSION的SPID(OS process)
sys@MAA> oradebug setospid 17678
Oracle pid: 25, Unix process pid: 17678, image: oracle@maa3.luocs.com (TNS V1-V3)
或者指定跟蹤SESSION的PID(Oracle process ID)
sys@MAA> oradebug setorapid 25
Oracle pid: 25, Unix process pid: 17678, image: oracle@maa3.luocs.com (TNS V1-V3)
sys@MAA> oradebug unlimit
sys@MAA> oradebug event 10053 trace name context forever, level 1
sys@MAA> exec our code
sys@MAA> oradebug event 10053 trace name context off
sys@MAA> oradebug tracefile_name
4.使用autotrace 跟蹤當前會話:
@MAA> set autotrace on
@MAA> set autotrace on explain
@MAA> set autotrace on statistics
@MAA> set autotrace traceonly
@MAA> set autotrace traceonly explain
@MAA> set autotrace traceonly explain statistics
@MAA> set autotrace off
我喜歡使用縮略方式,比如
@MAA> set autot trace exp stat
5.使用10053跟蹤會話:
MAA> alter session set events '10053 trace name context forever, level 1';
MAA> alter session set events '10053 trace name context off';
MAA> oradebug event 10053 trace name context forever, level 1
MAA> oradebug event 10053 trace name context off
alter session set events '10046 trace name context forever,level 1';
執行相關sql
alter session set events '10046 trace name context off';
2.3 獲取個人的sid,serail#
select sid, serial# from v$session where sid = (select sid from v$mystat where rownum=1);
獲取系統級別的會話:
select s.sid,s.serial#,s.username,s.osuser
from v$session s,v$process p
where s.paddr=p.addr;
3.使用oracledebug 跟蹤會話
3.1 使用ORADEBUG跟蹤當前會話
oradebug只能跟蹤SYS使用者的當前SESSION,如下方式:
sys@MAA> oradebug setmypid
sys@MAA> oradebug unlimit
sys@MAA> oradebug event 10046 trace name context forever, level 12
sys@MAA> exec our code
sys@MAA> oradebug event 10046 trace name context off
sys@MAA> oradebug tracefile_name
/u01/app/oracle/diag/rdbms/maa/maa/trace/maa_ora_17641.trc
3.2 使用ORADEBUG跟蹤其他會話
透過oradebug非常方便地跟蹤其他會話,如下方式:
luocs@MAA> select pid, spid from v$process p, v$session s where p.addr = s.paddr and s.sid=(select sid from v$mystat where rownum=1);
PID SPID
---------- ------------------------------------------------
25 17678
指定跟蹤SESSION的SPID(OS process)
sys@MAA> oradebug setospid 17678
Oracle pid: 25, Unix process pid: 17678, image: oracle@maa3.luocs.com (TNS V1-V3)
或者指定跟蹤SESSION的PID(Oracle process ID)
sys@MAA> oradebug setorapid 25
Oracle pid: 25, Unix process pid: 17678, image: oracle@maa3.luocs.com (TNS V1-V3)
sys@MAA> oradebug unlimit
sys@MAA> oradebug event 10053 trace name context forever, level 1
sys@MAA> exec our code
sys@MAA> oradebug event 10053 trace name context off
sys@MAA> oradebug tracefile_name
4.使用autotrace 跟蹤當前會話:
@MAA> set autotrace on
@MAA> set autotrace on explain
@MAA> set autotrace on statistics
@MAA> set autotrace traceonly
@MAA> set autotrace traceonly explain
@MAA> set autotrace traceonly explain statistics
@MAA> set autotrace off
我喜歡使用縮略方式,比如
@MAA> set autot trace exp stat
5.使用10053跟蹤會話:
MAA> alter session set events '10053 trace name context forever, level 1';
MAA> alter session set events '10053 trace name context off';
MAA> oradebug event 10053 trace name context forever, level 1
MAA> oradebug event 10053 trace name context off
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25462274/viewspace-2120620/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 一步一步教你使用Eclipse如何建立Swing專案(一)Eclipse
- 檔案-跟蹤檔案
- Oracle 跟蹤檔案和檔案轉儲(dump)Oracle
- 一步一步教你如何用Python做詞雲Python
- [zt] oracle跟蹤檔案與跟蹤事件Oracle事件
- oracle跟蹤檔案與跟蹤事件(zt)Oracle事件
- oracle跟蹤檔案和跟蹤事件(zt)Oracle事件
- 轉:使用 Tkprof 分析 ORACLE 跟蹤檔案Oracle
- Oracle跟蹤檔案Oracle
- Midjourney:一步一步教你如何使用 AI 繪畫 MJAI
- 一步一步教你如何搭建自己的視訊聚合站
- Oracle跟蹤檔案trace檔案Oracle
- 玩轉跟蹤(to owner session、other session)Session
- 轉載 oracle 跟蹤檔案 和轉儲命令Oracle
- oracle 跟蹤檔案和轉儲命令(轉摘)Oracle
- 一步一步教你 https 抓包HTTP
- Android 一步一步教你使用ViewDragHelperAndroidView
- (轉) 一步一步學習ASP.NET 5 (二)- 通過命令列和sublime建立專案ASP.NET命令列
- 解析listener跟蹤檔案
- git 忽略跟蹤檔案Git
- 尋找跟蹤檔案
- 控制檔案的跟蹤檔案全文
- 進一步學習對話方塊(轉)
- Android教你一步一步從學習貝塞爾曲線到實現波浪進度條Android
- 一步步學習如何用Lerna
- oracle 跟蹤檔案和轉儲命令詳解Oracle
- 一步一步教你寫kubernetes sidecarIDE
- 一步一步教你認識 Python 閉包Python
- Git跟蹤與提交檔案Git
- 獲取跟蹤檔案位置
- 獲取跟蹤檔案_eygle
- 跟蹤 sql 的trace檔案SQL
- tkprof: 分析ORACLE跟蹤檔案Oracle
- 一步一步教你封裝最新版的Dio封裝
- 如何一步一步配置webpackWeb
- oracle 跟蹤檔案和轉儲命令及常用轉儲命令(轉)Oracle
- 一步步教你如何使用 laradock 搭建專案環境
- ORACLE 10046 設定跟蹤事件後無跟蹤檔案Oracle事件