关于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
       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
       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
       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
       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
       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
后期补充。

时间: 2024-10-16 14:22:36

关于oracle中session跟踪的总结的相关文章

在Oracle中session和process的区别(转)

对应元数据表 v$resource_limit. 相互关系 sessions=1.1 * processes + 5 ,至于开多少个进程和你的用户并发数有关. 如果修改要修改数据库初始化参数,processes 和session 在Oracle中session和process的区别 问:在Oracle中session和process的区别是什么?答:一.一个process可以有0个.1个或者多个session,一个 session也可以存在若干个process中,并行同样是一个session对应

Oracle中如何跟踪事件

一.Oracle跟踪文件 Oracle跟踪文件分为三种类型,一种是后台报警日志文件,记录数据库在启动.关闭和运行期间后台进程的活动情况,如表空间创建.回滚段创建.某些alter命令.日志切换.错误消息等.在数据库出现故障时,应首先查看该文件,但文件中的信息与任何错误状态没有必然的联系.后台报警日志文件保存BACKGROUND_DUMP_DEST参数指定的目录中,文件格式为SIDALRT.LOG.另一种类型是DBWR.LGWR.SMON等后台进程创建的后台跟踪文件.后台跟踪文件根据后台进程运行情况

使用logon trigger完成动态的session跟踪

在之前讨论过 关于oracle中session跟踪的总结,可以参见链接 http://blog.itpub.net/23718752/viewspace-1150568/ 基本的session跟踪方法都做了讨论,但是在实际应用中场景可能要复杂一些,比如我们可以对指定的session开诊断事件,如果session中运行的某个环节出现问题,可以根据诊断事件得到比较明细的递归sql来逐步查看排除,知道问题的根源. 但是如果不确定session的情况,因为每次连接进来的session都是不固定的,这样就

Oracle中Kill session的研究

oracle|session Oracle中Kill session的研究   作者: Eygle link: http://www.eygle.com/faq/Kill_Session.htm 我们知道,在Oracle数据库中,可以通过kill session的方式来终止一个进程,其基本语法结构为: alter system kill session 'sid,serial#' ;   被kill掉的session,状态会被标记为killed,Oracle会在该用户下一次touch时清除该进程

Oracle中v$session和v$process的使用方法

查看当前session的sid和serial#: SYS@ORCL>select sid,serial#,status from v$session where sid=userenv('sid');     SID    SERIAL# STATUS ---------- ---------- --------      89          3 ACTIVE 查看当前session对应的spid: SYS@ORCL>select spid from v$process p, v$sess

Oracle中的Connect/session和process的区别及关系介绍_oracle

Session:在计算机中,尤其是在网络应用中,称为"会话". Session:在计算机专业术语中,Session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间. Connect.session.process的区别: 一个数据库的Connect可以有一个或多个session,同时connect也可以有一个或多个process. 在专业服务器连接方式中,一个session对应一个process,在共享服务器方式中,一个process可以

oracle中tkprof程序详解

现对tkprof程序做进一步的说明: 在打开跟踪功能后,oracle将被跟踪session中正在执行的SQL的性能状态数据都收集到一个跟踪文件中.这个跟踪文件提供了许多有用的信息,例如一个sql的解析次数.执行次数.fetch次数.物理读次数.逻辑读次数.CPU使用时间等,利用这些信息可以诊断你的sql的问题,从而用来优化你的系统.不幸的是,生成的跟踪文件中的数据是我们难以理解的,所以要用TKPROF工具对其进行转换,转换成我们易于理解格式.tkprof是oracle提供的实用工具,类似于sql

Oracle中获取执行计划的几种方法分析

以下是对Oracle中获取执行计划的几种方法进行了详细的分析介绍,需要的朋友可以参考下   1. 预估执行计划 - Explain PlanExplain plan以SQL语句作为输入,得到这条SQL语句的执行计划,并将执行计划输出存储到计划表中. 首先,在你要执行的SQL语句前加explain plan for,此时将生成的执行计划存储到计划表中,语句如下: explain plan for SQL语句然后,在计划表中查询刚刚生成的执行计划,语句如下: select * from table(

Oracle中的游标、硬解析、软解析、软软解析、解析失败

Oracle中的游标.硬解析.软解析.软软解析.解析失败 一. 游标的分类及共享游标 游标(Cursor)是Oracle数据库中SQL解析和执行的载体,它可以分为共享游标(Shared Cursor)和会话游标(Session Cursor).共享游标可以细分为父游标(Parent Cursor)和子游标(Child Cursor),可以通过视图V$SQLAREA和V$SQL来查看当前缓存在库缓存(Library Cache)中的父游标和子游标,其中V$SQLAREA用于查看父游标,V$SQL用