教你如何收集Oracle进程中SQL跟踪信息

2016-02-19 14:36 2 1 收藏

给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的教你如何收集Oracle进程中SQL跟踪信息,过去的都会过去,迎接崭新的开始,释放更美好的自己。

【 tulaoshi.com - 编程语言 】

    在诊断数据库系统性能的过程中,总会涉及到跟踪效率低下的SQL语句,现在就如何跟踪SQL语句来做一个简单的总结。

     假如我们可以修改应用系统的源代码,则可以直接在程序中加入如下的语句:

     1)alter session set timed_statistics=true;
/*适用于Oracle 7.3以后的版本*/

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

     2)alter session set max_dump_file_size=unlimited ;
 /*适用于Oracle 7.3以后的版本*/

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

     3)alter session set tracefile_identifier='POX20031031a';
/*适用于Oracle 8.1.7以后的版本*/

     4)alter session set events '10046 trace name context forever, level 8'; /*在这里编写应用程序的代码*/ 小虫网络技术http://www.chinaccna.com 

    5)alter session set events '10046 trace name context off';

      在上述语句中,语句1)是把该会话的时间统计打开,该参数默认为false.在Oracle 7.3之前的版本中,不能在会话级设置该参数,只能修改初始化文件然后重新启动数据库,这样将在实例级打开时间统计。

     语句2)是把跟踪文件的大小设置成操作系统所答应的最大尺寸,这样可以防止跟踪文件在完成所需要的跟踪之前被填布满,此外需要注重的是确保存放跟踪文件的目录要有足够的空间,否则将会收到“文件系统已满”错误。

     语句3)的作用是使生成的跟踪文件名称中包含'POX20031031a'字符串,这样可以使你很轻易的找到所需的跟踪文件,该参数在Oracle 8.1.7之后可用。

     语句4)和语句5)的作用分别是打开和关闭跟sql跟踪,你可以在这两个语句之间写入应用程序的代码,这些代码的执行情况都将被跟踪。需要注重的是语句4)的level要害字,它用来指定跟踪级别,一共有0,1,2,4,8,12六个级别可以设置,0相当于关闭跟踪;1是输出一般的跟踪信息,不包括绑定变量和等待信息;2和1相同;4是在级别1的基础上增加绑定变量信息;8是在级别1的基础上增加等待信息;级别12是输出包含级别1,4,8的所有信息。

     假如应用程序的代码无法修改或者是不想去修改,则可以在其他会话中打开对特定会话的跟踪,方法如下:

    1)sys.dbms_system.set_bool_param_in_session (:sid, :serial,'timed_statistics', true);

     2)sys.dbms_system.set_int_param_in_session ( :sid, :serial,'max_dump_file_size', 2147483647);
打开和关闭跟踪的第一种方法(Oracle推荐):

    3.1)sys.dbms_support.start_trace_in_session (:sid, :serial,waits=true, binds=false); /* 在此期间运行要跟踪的应用程序*/

    4.1)sys.dbms_support.stop_trace_in_session (:sid, :serial);

    打开和关闭跟踪的第二种方法:

    3.2)sys.dbms_system.set_ev (:sid, :serial, 10046, 8, '');

  /*在此期间运行要跟踪的应用程序*/

    3.2)sys.dbms_system.set_ev (:sid, :serial, 10046, 0, '');

    以上语句中的:sid和:serial分别代表所要跟踪的会话的ID和序列号,这些信息可以从V$SESSION视图的SID和SERIAL#列获得。打开关闭跟踪中第一种方法的好处是你不用自己写10046这个事件号,这样可以减少错误,但是dbms_support程序包在你的数据库中可能会不存在,这样就只有用第二种方法了。

     到现在为止,我们已经生成了所需要的跟踪文件,然后我们需要找到该文件来进行分析。跟踪文件的存放位置只有两种可能,Oracle参数USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目录;文件名称根据不同的平台会有所不同,但是在文件名中都会包含会话所对应的操作系统进程(线程)号,也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,该信息可以通过 v$process.addr和v$session.paddr做表连接查询得到。例如:select spid from v$process p,v$session s where p.addr=s.paddr and s.sid=:sid and s.serial#=:serial.

    本文只对Oracle在使用专用服务器进程(Dedicated Server)模式做了总结,至于的共享服务器(Shared Server)模式和在应用级使用连接池的情况下,收集SQL跟踪信息的方法会比较复杂,希望有相关经验的高手来总结。

来源:https://www.tulaoshi.com/n/20160219/1607331.html

延伸阅读
显示某个Sql Server某个数据库中所有表或视图的信息 sql server 2000 与 2005 不同 差别在于 红色字部分 以下语句为获取所有表信息,替换绿色黑体字"U"为"V"为获取所有视图信息。 Sql Server 2000 版本 SELECT Sysobjects.name AS TABLE_NAME, syscolumns.Id, syscolumns.name AS COLUMN_NAME, systypes.name AS DATA_TYPE, syscolumns.le...
标签: SQLServer
  本文通过实际业务系统中调整的一个案例,试图给出一个常见CPU消耗问题的一个诊断方法.大多数情况下,系统的性能问题都是由不良SQL代码引起的,那么作为DBA,怎样发现和解决这些SQL问题就显得尤为重要. 本案例平台为UNIX,所以不可避免的应用了一些Unix下常用的工具.如vmstat,top等. 本文适宜读者范围:中高级. 系...
Oracle SQL 语句可以分为以下几类: 数据操作语言语句[Data manipulation language,DML] 从一个或多个表或视图中查询数据(SELECT);获取操作[fetch]是可滚动 的[scrollable](见“可滚动游标”) 向表或视图中加入新数据行(INSERT) 修改表或视图中已有数据行的列值(UPDATE) 根据判断条件为表及视图插入或更新数...
标签: SQLServer
使用SQL服务器调节器(SQL Server Profiler)工具可以收集服务器当前活动的重要信息。被这个Profiler工具所追踪到的信息(包含有数据库的真实负载)能够被用在多种场合里。现在让我们来看看如何使用Profiler收集能够被索引调节向导所使用的数据,以及你该如何使用这些工具来调试你的应用程序。 什么时候使用它? Profiler工具能够用在数...
在我供职的公司不仅仅拥有Oracle数据库,同时还拥有SQL Server数据库,所以我经常遇见人们向我提两种问题。 第一种通常都是以"你能教我使用Oracle吗?"开始的,对此我比较礼貌的回答一般是"当然可以,实际上我正准备办个Oracle学习班;准备好之后我就叫你"。这是做好人的办法,我没有告诉询问者这可能花费我数周的精力。有时候我进一...

经验教程

227

收藏

6
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部