關於oracle中session跟蹤的總結
資料庫中的session在操作中可能會有各種各樣的問題,比如一條sql語句執行失敗,某一個應用在一些特定的場景下就會有一些效能問題等等,有時候在程式碼層去做一些debug來說肯定是不實際的,而且也不一定能夠迅速的排查問題,對於session的監控顯得尤為重要。可以靈活的開啟和關閉,在資料庫層面,session層面,甚至特定的應用層面都能夠進行監控,今天和大家分享一下對於的session監控常用的一些方法。
1.dbms_system.set_sql_trace_in_session 可以對其他的session進行跟蹤,功能比較全面,在早期版本中使用比較多。
2.dbms_system.set_ev 可以靈活的指定相應的診斷時間,可以對其他的session進行跟蹤,功能比較全面。
3.dbms_monitor 在10g,11g及後期版本中大量使用。可以對其他的session進行跟蹤,說是dbms_system的升級版本。
4.sql_trace 對當前session進行跟蹤。
5.session level event 對當前的的session進行跟蹤。
6.oradebug 可以繫結程式,session
對於oradebug,個人想專門開一個專題,自己好好琢磨一下,稍後分享,這篇文章會對以上的5種方法進行總結。
1.dbms_system.set_sql_trace_in_session
啟用兩個session
session1:
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 9
session 2:
查到具體的session資訊以後,開始進行跟蹤。
SQL> exec dbms_system.set_sql_trace_in_session(254,9,true);
PL/SQL procedure successfully completed.
session1:
在session1中進行一些操作,以便跟蹤。
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
關閉跟蹤。
SQL> exec dbms_system.set_sql_trace_in_session(254,9,false);
PL/SQL procedure successfully completed.
trace files:
得到具體的trace檔案,可以使用tkprof進行格式化。
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=9);
SPID
------------------------
2688
-rw-r----- 1 ora11g dba 128 Apr 27 01:43 TEST01_ora_2688.trm
-rw-r----- 1 ora11g dba 3871 Apr 27 01:43 TEST01_ora_2688.trc
如果稍後對session再次開啟trace,是append的模式,新的日誌會在已有的trace檔案中插入新的記錄
-rw-r----- 1 ora11g dba 209 Apr 27 01:46 TEST01_ora_2688.trm
-rw-r----- 1 ora11g dba 6470 Apr 27 01:46 TEST01_ora_2688.trc
2.dbms_system.set_ev
session1:
得到要監控的session的資訊
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 17
session2:
開啟監控。
SQL> exec dbms_system.set_ev(254,17,100046,12,'');
PL/SQL procedure successfully completed.
--雖然定義的事件不正確,但是還是執行成功,不過不會有trace日誌生成。
重新開啟監控
SQL> exec dbms_system.set_ev(254,17,10046,12,'');
PL/SQL procedure successfully completed.
session1:
開始一些操作,以便跟蹤。
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
結束監控
SQL> exec dbms_system.set_ev(254,17,10046,0,'');
PL/SQL procedure successfully completed.
檢視trace日誌
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=17);
SPID
------------------------
3497
-rw-r----- 1 ora11g dba 100 Apr 27 04:10 TEST01_ora_3497.trm
-rw-r----- 1 ora11g dba 3294 Apr 27 04:10 TEST01_ora_3497.trc
3.dbms_monitor
session1:
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 7
session2:
開啟監控
SQL> exec dbms_monitor.session_trace_enable(254,7);
PL/SQL procedure successfully completed.
session1:
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
結束監控。
SQL> exec dbms_monitor.session_trace_disable(254,7);
PL/SQL procedure successfully completed.
trace files:
SQL> select process,paddr,sid from v$session where sid=254;
PROCESS PADDR SID
------------------------ ---------------- ----------
2560 000000007278E200 254
檢視v$process得到spid
SPID PID USERNAME
------------------------ ---------- ---------------
2561 27 ora11g
-rw-r----- 1 ora11g dba 454 Apr 27 01:35 TEST01_ora_2561.trm
-rw-r----- 1 ora11g dba 29887 Apr 27 01:35 TEST01_ora_2561.trc
4.sql_trace
只針對當前session
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 13
開啟sql跟蹤
SQL> alter session set sql_trace=true;
Session altered.
SQL> select count(*)from cat;
COUNT(*)
----------
2
關閉sql跟蹤
SQL> alter session set sql_trace=false;
Session altered.
trace files:
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=13);
SPID
------------------------
2780
-rw-r----- 1 ora11g dba 121 Apr 27 01:52 TEST01_ora_2780.trm
-rw-r----- 1 ora11g dba 3594 Apr 27 01:52 TEST01_ora_2780.trc
5.session level event
開啟診斷事件,
10046常用的level有1,2,8,12 當前session中檢視trace 日誌
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 11
開啟跟蹤
SQL> alter session set events '10046 trace name context forever,level 12';
Session altered.
SQL> select count(*)from cat;
COUNT(*)
----------
2
結束跟蹤
SQL> alter session set events '10046 trace name context off';
Session altered.
trace files:
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=11);
SPID
------------------------
2713
-rw-r----- 1 ora11g dba 134 Apr 27 01:50 TEST01_ora_2713.trm
-rw-r----- 1 ora11g dba 4087 Apr 27 01:50 TEST01_ora_2713.trc
6.oradebug
後期補充。
1.dbms_system.set_sql_trace_in_session 可以對其他的session進行跟蹤,功能比較全面,在早期版本中使用比較多。
2.dbms_system.set_ev 可以靈活的指定相應的診斷時間,可以對其他的session進行跟蹤,功能比較全面。
3.dbms_monitor 在10g,11g及後期版本中大量使用。可以對其他的session進行跟蹤,說是dbms_system的升級版本。
4.sql_trace 對當前session進行跟蹤。
5.session level event 對當前的的session進行跟蹤。
6.oradebug 可以繫結程式,session
對於oradebug,個人想專門開一個專題,自己好好琢磨一下,稍後分享,這篇文章會對以上的5種方法進行總結。
1.dbms_system.set_sql_trace_in_session
啟用兩個session
session1:
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 9
session 2:
查到具體的session資訊以後,開始進行跟蹤。
SQL> exec dbms_system.set_sql_trace_in_session(254,9,true);
PL/SQL procedure successfully completed.
session1:
在session1中進行一些操作,以便跟蹤。
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
關閉跟蹤。
SQL> exec dbms_system.set_sql_trace_in_session(254,9,false);
PL/SQL procedure successfully completed.
trace files:
得到具體的trace檔案,可以使用tkprof進行格式化。
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=9);
SPID
------------------------
2688
-rw-r----- 1 ora11g dba 128 Apr 27 01:43 TEST01_ora_2688.trm
-rw-r----- 1 ora11g dba 3871 Apr 27 01:43 TEST01_ora_2688.trc
如果稍後對session再次開啟trace,是append的模式,新的日誌會在已有的trace檔案中插入新的記錄
-rw-r----- 1 ora11g dba 209 Apr 27 01:46 TEST01_ora_2688.trm
-rw-r----- 1 ora11g dba 6470 Apr 27 01:46 TEST01_ora_2688.trc
2.dbms_system.set_ev
session1:
得到要監控的session的資訊
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 17
session2:
開啟監控。
SQL> exec dbms_system.set_ev(254,17,100046,12,'');
PL/SQL procedure successfully completed.
--雖然定義的事件不正確,但是還是執行成功,不過不會有trace日誌生成。
重新開啟監控
SQL> exec dbms_system.set_ev(254,17,10046,12,'');
PL/SQL procedure successfully completed.
session1:
開始一些操作,以便跟蹤。
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
結束監控
SQL> exec dbms_system.set_ev(254,17,10046,0,'');
PL/SQL procedure successfully completed.
檢視trace日誌
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=17);
SPID
------------------------
3497
-rw-r----- 1 ora11g dba 100 Apr 27 04:10 TEST01_ora_3497.trm
-rw-r----- 1 ora11g dba 3294 Apr 27 04:10 TEST01_ora_3497.trc
3.dbms_monitor
session1:
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 7
session2:
開啟監控
SQL> exec dbms_monitor.session_trace_enable(254,7);
PL/SQL procedure successfully completed.
session1:
SQL> select count(*)from cat;
COUNT(*)
----------
2
session2:
結束監控。
SQL> exec dbms_monitor.session_trace_disable(254,7);
PL/SQL procedure successfully completed.
trace files:
SQL> select process,paddr,sid from v$session where sid=254;
PROCESS PADDR SID
------------------------ ---------------- ----------
2560 000000007278E200 254
檢視v$process得到spid
SPID PID USERNAME
------------------------ ---------- ---------------
2561 27 ora11g
-rw-r----- 1 ora11g dba 454 Apr 27 01:35 TEST01_ora_2561.trm
-rw-r----- 1 ora11g dba 29887 Apr 27 01:35 TEST01_ora_2561.trc
4.sql_trace
只針對當前session
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 13
開啟sql跟蹤
SQL> alter session set sql_trace=true;
Session altered.
SQL> select count(*)from cat;
COUNT(*)
----------
2
關閉sql跟蹤
SQL> alter session set sql_trace=false;
Session altered.
trace files:
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=13);
SPID
------------------------
2780
-rw-r----- 1 ora11g dba 121 Apr 27 01:52 TEST01_ora_2780.trm
-rw-r----- 1 ora11g dba 3594 Apr 27 01:52 TEST01_ora_2780.trc
5.session level event
開啟診斷事件,
10046常用的level有1,2,8,12 當前session中檢視trace 日誌
SQL> select sid from v$mystat where rownum<2;
SID
----------
254
SQL> select sid,serial# from v$session where sid=254;
SID SERIAL#
---------- ----------
254 11
開啟跟蹤
SQL> alter session set events '10046 trace name context forever,level 12';
Session altered.
SQL> select count(*)from cat;
COUNT(*)
----------
2
結束跟蹤
SQL> alter session set events '10046 trace name context off';
Session altered.
trace files:
SQL> select spid from v$process where addr=(select paddr from v$session where sid=254 and serial#=11);
SPID
------------------------
2713
-rw-r----- 1 ora11g dba 134 Apr 27 01:50 TEST01_ora_2713.trm
-rw-r----- 1 ora11g dba 4087 Apr 27 01:50 TEST01_ora_2713.trc
6.oradebug
後期補充。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8494287/viewspace-1349349/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何收集Oracle程式中的SQL跟蹤資訊KUOracleSQL
- Oracle資料庫跟蹤SQLOracle資料庫SQL
- C中關於堆疊的總結
- oracle跟蹤常用內部事件號Oracle事件
- 關於Vue中插槽的理解和總結Vue
- 關於oracle中的undoOracle
- 關於近期的總結
- 【經典】連線oracle的總結(關於tnsname和監聽)Oracle
- 轉:使用 Tkprof 分析 ORACLE 跟蹤檔案Oracle
- Oracle:優化方法總結(關於連表查詢)Oracle優化
- cookie、session總結CookieSession
- 使用dbms_monitor.session_trace_enable跟蹤一個會話Session會話
- [20211227]抽取跟蹤檔案中的繫結變數值.txt變數
- AI開發實踐:關於停車場中車輛識別與跟蹤AI
- mysql關於variable的總結MySql
- sqlserver關於always on的總結SQLServer
- [20190917]oracle跟蹤事件簡單寫法.txtOracle事件
- Session跟蹤機制是怎樣的?網路安全技術學習Session
- 筆記:React 中關於 key 的一點總結筆記React
- keycloak~關於session idle和session max的解釋Session
- sqlserver 關於DBCC CHECKDB的總結SQLServer
- sqlserver關於mirror映象的總結SQLServer
- 關於golang的time包總結Golang
- 關於Session和CookieSessionCookie
- 關於Servlet小總結Servlet
- Oracle執行語句跟蹤 使用sql trace實現語句追蹤OracleSQL
- JVM中的本機記憶體跟蹤JVM記憶體
- 如何在 Git 中取消檔案的跟蹤Git
- 跟蹤Kubernetes中的網路流量路徑
- 中移智庫:2019-2020年騰訊發展跟蹤總結報告(附下載)
- 在Unity中實現手部跟蹤Unity
- mysql關於mysqld_safe的總結MySql
- mysql關於mysql.server的總結MySqlServer
- 關於PaaS的純乾貨總結
- mysql關於表空間的總結MySql
- 關於Android Studio使用Git的總結AndroidGit
- 關於STL容器的簡單總結
- SqlServer關於分割槽表的總結SQLServer
- postgresql關於許可權的總結SQL