Oracle执行语句跟踪(1)——使用sql trace实现语句追踪

系统上的某个接口提交数据经常超时(超过3秒),而我单独在后台数据库(Oracle)执行insert,只需要17ms。提交数据的客户端没有任何的调试日志,只能通过跟踪后台语句记录实际调用过程中的数据库执行时间。从而发现问题耗时最多的阶段。

安装dbms_support包

SQL> @?\rdbms\admin\dbmssupp.sql
SQL> grant execute on dbms_support to test;

找到需要跟踪的会话,一个接口可能会建立多个会话,需要根据会话建立的时间来判断真正需要跟踪的会话。

SQL> alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
SQL> select sid,serial#,logon_time from v$session where username=&name and program=&program;
输入 name 的值:  'test'
输入 program 的值:  'test.exe'

使用start_trace_in_session进行跟踪

SQL>exec dbms_support.start_trace_in_session(1157,59729,TRUE,TRUE);

开始跟踪后,在客户端进行对应的操作。

使用stop_trace_in_session结束跟踪

SQL> exec dbms_support.stop_trace_in_session(1157,59729);

使用以下的语句获得trace文件的位置。


     SELECT    d.VALUE 
          || '\' 
          || LOWER (RTRIM (i.INSTANCE, CHR (0))) 
          || '_ora_' 
          || p.spid 
          || '.trc' trace_file_name 
     FROM (SELECT p.spid 
             FROM v$mystat m, v$session s, v$process p 
            WHERE m.statistic# = 1 AND s.SID = &SID AND p.addr = s.paddr) p, 
          (SELECT t.INSTANCE 
             FROM v$thread t, v$parameter v 
            WHERE v.NAME = 'thread' 
              AND (v.VALUE = 0 OR t.thread# = TO_NUMBER (v.VALUE))) i, 
          (SELECT VALUE 
             FROM v$parameter 
            WHERE NAME = 'user_dump_dest') d 

用文本编辑器可以直接打开trace文件

图中的这一段就是对一个语句的从解析到返回数据的整个过程,如果统计从开始请求到消息返回客户端的时间,直接将红框中的两个tim相减就可以了,11592216806504-11592199796058=17010446,其单位是1/1000000秒。若要单独获取执行时间,可以EXEC的TIM减掉PARSE的TIM,差值即为执行的时间。其它字段的说明可以参照这个文档

另外也可以使用TKPROF将trace文件转换成为执行计划解析的文本。


D:\app\oracle\diag\rdbms\wxmesdb\wxmesdb\trace>tkprof wxmesdb_ora_6520.trc trace_1.txt

TKPROF: Release 12.1.0.1.0 - Development on 星期三 1 6 08:30:11 2016

Copyright (c) 1982, 2013, Oracle and/or its affiliates.  All rights reserved.

如上图所示,可以得到执行时间为17秒,与上一步中通过TIM相减的差值一致。

--EOF--

posted on 2016-01-06 09:28  camash  阅读(12861)  评论(0)    收藏  举报

编辑推荐:
· 于是转身独立开发者
· C#.Net筑基-泛型T & 协变逆变
· dotnet 代码调试方法
· DbContext是如何识别出实体集合的
· 一次 .NET 性能优化之旅:将 GC 压力降低 99%
阅读排行:
· 我救了一个网站,性能提升了1500 多倍!
· .NET程序员的多语言笔记本:Polyglot Notebook
· 免费开源 .NET OpenCV 迷你运行时全平台发布
· 经验贴!万字总结网卡丢包及ping延迟等网络问题排查思路
· 用好索引的10条军规

导航

< 2025年7月 >
29 30 1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31 1 2
3 4 5 6 7 8 9

统计

点击右上角即可分享
微信分享提示