关于oracle中session跟踪的总结(56天)
发布日期:2021-06-30 13:23:30 浏览次数:2 分类:技术文章

本文共 2980 字,大约阅读时间需要 9 分钟。

数据库中的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_sessionsession1:session 2:session1:session2:trace files:2.dbms_system.set_evSQL> select sid from v$mystat where rownum<2; SID---------- 254SQL> select sid,serial# from v$session where sid=254; SID SERIAL#---------- ---------- 254 17session2:开启监控。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(*)---------- 2session2:结束监控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.trc3.dbms_monitorsession1:SQL> select sid from v$mystat where rownum<2; SID---------- 254SQL> select sid,serial# from v$session where sid=254; SID SERIAL#---------- ---------- 254 7session2:SQL> exec dbms_monitor.session_trace_enable(254,7);PL/SQL procedure successfully completed.session1:SQL> select count(*)from cat; COUNT(*)---------- 2session2: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得到spidSPID 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针对当前sessionSQL> select sid from v$mystat where rownum<2; SID---------- 254SQL> 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.trc5.session level event开启诊断事件开启跟踪结束跟踪trace files:6.oradebug

转载地址:https://jeanron100.blog.csdn.net/article/details/102506242 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:session跟踪失效的问题和分析(57天)
下一篇:oracle共享服务器配置汇总(53天)

发表评论

最新留言

很好
[***.229.124.182]2024年04月23日 20时57分06秒