Oracle性能分析1:开启SQL跟踪和获取trace文件

当Oracle查询出现效率问题时,我们往往需要了解问题所在,这样才能针对问题给出解决方案。Oracle提供了SQL执行的trace信息,其中包含了SQL语句的文本信息,一些执行统计,处理过程中的等待,以及解析阶段(如生成执行计划)产生的信息。这些信息有助于你分解sql语句的服务时间和等待时间,并了解所用资源和同步点的详细信息,从而帮助你诊断存在的性能问题。

这篇文章介绍了怎么开启SQL跟踪和获取trace文件,详细信息如下。

开启SQL跟踪

从内部技术细节看,SQL跟踪是基于10046调试事件的,下面是支持的等级:

 0

禁止调试事件

 1

调试事件是激活的。针对每个被处理的数据库调用,给定如下信息:SQL语句、响应时间、服务时间

处理的行数、处理的行数、逻辑读数量、物理读与写的数量、执行计划以及一些额外信息

4

如果等级1,包括绑定变量的额外信息。主要是数据类型、精度以及每次执行时所用的值

8

同等级1,加上关于等待时间的细节信息。为了处理过程中的每个等待,提供如下信息:等待时间的名字、持续时间,以及一些额外的参数,可标明所等待的资源

12

同时启动等级4和等级8

在Oracle 9i或者之前,下面SQL语句针对所在会话激活SQL跟踪:

alter session set sql_trace = true

还可通过dbms_session包中的set_sql_trace存储过程,或者通过dbms_system包的set_sql_tarce_in_session存储过程方法,但这些都只是在等级1激活SQL跟踪,在实践中用处不大,就不详述了。

更有用的是指定级别的方式,下面是对所在会话开始等级12的SQL跟踪:

alter session set events '10046 trace name context forever, level 12'

对应的对所在会话禁止SQL跟踪的语句如下:

alter session set events '10046 trace name context off'

也可以通过dbms_system包中的set_ev存储过程,这里也不详述了,我下面重点讲讲Oracle 10g之后提供的方法。

Oracle 10g之后提供了dbms_monitor包来开启或关闭SQL跟踪,提供了在会话、客户端、组件以及数据库层级开启SQL跟踪方法,注意只有dba角色的用户才允许使用。

会话级

下面的PL/SQL为ID为122,序列号为6734的会话开启第8级的SQL跟踪:

begin
  dbms_monitor.session_trace_enable(session_id => 122,
                                    serial_num => 6734,
                                    waits      => true,
                                    binds      => false);
end;

session_id

session标识,对应v$session视图中的SID列,下面是获取当前会话id的方法:

select userenv('sid') from dual

serial_num

对应v$session视图中的SERIAL#列,由于SID会重用,当SID被重用时,SERIAL#增加,获取方法如下:

select serial# from v$session where sid = 122

waits

对应v$session视图中的SQL_TRACE_WAITS,表示等待事件跟踪是否被激活,默认为true。

binds

对应v$session视图中的SQL_TRACE_BINDS,表示绑定跟踪是否被激活,默认false。

当执行成功后,v$session视图中的SQL_TRACE被修改为ENABLED,SQL_TRACE_WAITS和SQL_TRACE_BINDS为你设置的对应值。

下面的PL/SQL用于关闭SQL跟踪:

begin
  dbms_monitor.session_trace_disable(session_id => 122, serial_num => 6734);
end;

客户端级

下面的PL/SQL调用为所有具有指定客户端标记的会话开启第8级的SQL跟踪:

begin
  dbms_monitor.client_id_trace_enable(client_id => 'test',
                                      waits     => true,
                                      binds     => false);
end;

需要注意客户端标记区分大小写,可以通过下面的方法看是否设置成功:

select primary_id as client_id, waits, binds
  from dba_enabled_traces
 where trace_type = 'CLIENT_ID'

当设置成功后,每次查询前指定对应的客户端标记就可以开启SQL跟踪,指定客户端标记的方法如下:

begin
  DBMS_SESSION.SET_IDENTIFIER('test');
end;
//该会话的SQL跟踪已经开启

当你为一个session设置了标记后,可以在v$session的client_identifier列查看该标记。

下面的PL/SQL用于关闭SQL跟踪:

begin
  dbms_monitor.client_id_trace_disable(client_id => 'test');
end;

组件级

下面的PL/SQL调用为所有具有指定客户端标记的会话开启第8级的SQL跟踪:

begin
  dbms_monitor.serv_mod_act_trace_enable(service_name  => 'ly',
                                         module_name   => 'PL/SQL Developer',
                                         action_name   => 'SQL 窗口 - 新建',
                                         waits         => true,
                                         binds         => false,
                                         instance_name => null);
end;

参数中的service_name对应v$session视图的service_name,module_name对应v$session视图的的module,action_name对应v$session视图的action,查询方式如下:

SELECT sid, serial#,
            client_identifier, service_name, action, module
       FROM V$SESSION

设置之后可以通过如下方法查看设置:

select primary_id    as service_name,
       qualifier_id1 as module_name,
       qualifier_id2  as action_name,
       waits,
       binds
  from dba_enabled_traces
 where trace_type = 'SERVICE_MODULE_ACTION'

下面的PL/SQL用于关闭SQL跟踪:

begin
  dbms_monitor.serv_mod_act_trace_disable(service_name  => 'ly',
                                          module_name   => 'PL/SQL Developer',
                                          action_name   => 'SQL 窗口 - 新建',
                                          instance_name => null);
end;

数据库级

下面的PL/SQL调用开启了数据库的12级SQL跟踪:

begin
  dbms_monitor.database_trace_enable(waits         => true,
                                     binds         => true,
                                     instance_name => null);
end;

下面的方法查看设置是否成功:

select instance_name,
       waits,
       binds
  from dba_enabled_traces
 where trace_type = 'DATABASE'

下面的PL/SQL用于关闭SQL跟踪:

begin
  dbms_monitor.database_trace_disable(instance_name => null);
end;

trace文件中的计时信息

下面的语句用于为trace文件提供计时信息:

alter session set timed_statistics = true

一般情况下默认都为true,如果不提供计时信息,trace文件就没有什么用了,因此开启SQL跟踪之前,最好确认一下参数被设置为true。

获取生成的trace文件

开启SQL跟踪后,会生成一个trace文件,通过初始化参数user_dump_dest配置其所在目录,该参数的值可以通过下面方法获取到:

select name, value from v$parameter where name = 'user_dump_dest'

但如果我们需要定位到具体的文件,则需要了解trace文件的命名。trace文件的名字是独立于版本和平台的,在大部分常见的平台下,命名结构如下:

{instance name}_{process name}_{process id}.trc

1)instance name

初始化参数instance_name的小写值。通过v$instance视图的instance_name列可以得到这个值。

2)process name

产生跟踪文件进程的名字的小写值。对于专有服务器进程,使用ora,对于共享服务器进程,可以通过v$diapatcher或v$shared_server视图的name列获得。对于并行从属进程,可以通过v$px_process视图server_name列获得,对于其他多数后台进程来说,可以通过v$bgprocess视图的name列获得。

3)process id

操作系统层面的进程标记。这个值可以通过v$process视图的spid列获取。

根据这些信息,可以通过下面的方式获取trace文件名:

select s.SID,
       s.SERVER,
       lower(case
               when s.SERVER in ('DEDICATED', 'SHARED') then
                i.INSTANCE_NAME || '_' || nvl(pp.SERVER_NAME, nvl(ss.NAME, 'ora')) || '_' ||
                p.SPID || '.trc'
               else
                null
             end) as trace_file_name
  from v$instance      i,
       v$session       s,
       v$process       p,
       v$px_process    pp,
       v$shared_server ss
 where s.PADDR = p.ADDR
   and s.SID = pp.SID(+)
   and s.PADDR = ss.PADDR(+)
   and s.TYPE = 'USER'
   and s.SID = 'your sid'
 order by s.SID

将上面的‘your sid‘替换为你的session的sid就可以查出指定session生成的trace文件的名字,session的sid在v$session视图中得到,或者直接查询当前session的sid:

select userenv('sid') from dual

将路径(user_dump_dest)和文件名结合在一起,我们就得到了trace文件的完整路径。

而在Oracel 11g中,查询当前会话生成的trace文件则非常简单:

select value from v$diag_info where name = 'Default Trace File'

Oracle性能分析1:开启SQL跟踪和获取trace文件

时间: 2024-11-06 23:09:11

Oracle性能分析1:开启SQL跟踪和获取trace文件的相关文章

Oracle性能分析3:TKPROF介绍

tkprof是Oracle自带的一个命令行工具,主要作用是将原始的跟踪文件转换为格式化的文本文件,最简单的使用方式如下: tkprof ly_ora_128636.trc ly_ora_128636.txt tkprof带有很多参数,在多数情况下,使用这些参数对你的分析将很有帮助. tkprof参数 如果不带任何参数运行tkprof,它将打印出完整的参数列表,并带有简单的描述.下面是对参数的说明: explain 为每个SQL语句提供一个执行计划.该参数需要指定用户.密码,也可以指定数据库连接串

Oracle性能分析工具介绍及使用

oracle数据库级别优化分析工具介绍 当我们对数据库优化诊断时,需要收集相应的信息以供参考,从个人的使用经验来说,这种统计数据分为两大类 一类是数据库级别的统计信息二类是os级别的统计信息 下面就分别介绍在不同的级别下,常用什么工具来收集信息帮助优化诊断 首先是oracle数据库级别优化分析工具介绍 目录: 1.statspack2.ASH3.AWR4.ORACLE EXPLAIN PLAN的总结(查询sql的执行计划)   a.autotrace   b.explain的使用 1.stats

Oracle性能分析7:索引的使用

这一节主要讲述索引的使用,首先介绍怎么在查询中避免使用索引,然后介绍优化器怎么判断是否使用索引,并介绍了强制使用索引的方法,最后介绍了Oracle的并行处理方法. 避免使用索引 虽然你创建了索引,但有些查询你可能需要避免使用这些索引,或者你为了做一些测试,希望看看各种情况下查询的情况,也希望能够避免使用一些索引或者索引扫描方式.Oracle提供了方式来达到这些目地,就是在查询中使用hint信息,具体情况如下. 避免使用某个索引 如果索引的选择性很差,那么也许使用其它索引或者使用全表扫描的效率会更

Oracle性能分析4:数据访问方法之全扫描

SQL语句执行时,Oracle的优化器会根据统计信息确定表的访问方式,一般来说,有两种基本的数据访问方式:1)全扫描.在全扫描(全表扫描或者快速全索引扫描)中,多个块被读入到一个IO运算中.2)索引扫描.索引扫描首先扫描索引叶子块以取得特定的行id(rowid),然后利用这些行id来访问父表取得实际的行数据,访问通过单块读取来完成.这里主要讲解全扫描方式,后面将介绍索引扫描. 使用全扫描 当对一个表进行全扫描时,会将表中所有数据块(block)取出并进行处理,筛选出符合条件的数据.注意Oracl

Oracle性能分析2:trace文件解读

下面是trace文件中的一个片段,表示一个SQL执行的过程,一个trace文件由很多这样的片段组成: PARSING IN CURSOR #4 len=135 dep=1 uid=0 oct=3 lid=0 tim=777069789359 hv=1115215392 ad='33e7e384' select /*+ index(idl_char$ i_idl_char1) +*/ piece#,length,piece from idl_char$ where obj#=:1 and part

Oracle性能分析12:对象统计信息

对象统计信息描述数据是如何在数据库中存储的,查询优化器使用这些统计信息来做出正确的决定.Oracle中有三种类型的对象统计信息:表统计.列统计和索引统计.而在每种类型中,有细分为:表或索引级别的统计.分区级别统计和子分区级别的统计,后面两种只有在对象被分区和具有子分区的情况下才可用. 统计信息相关视图 表统计信息 表/索引级别的统计 user_tab_statistics user_tables 分区级别的统计 user_tab_statistics user_tab_partitions 子分

Oracle性能分析3:TKPROF简介

tkprof它是Oracle它配备了一个命令直插式工具,其主要作用是将原始跟踪文件格文本文件的类型,例如,最简单的方法,使用下面的: tkprof ly_ora_128636.trc ly_ora_128636.txt tkprof带有非常多參数,在多数情况下,使用这些參数对你的分析将非常有帮助. tkprof參数 假设不带不论什么參数执行tkprof,它将打印出完整的參数列表,并带有简单的描写叙述.以下是对參数的说明: explain 为每一个SQL语句提供一个运行计划. 该參数须要指定用户.

Oracle 性能相关常用脚本(SQL)

在缺乏的可视化工具来监控数据库性能的情形下,常用的脚本就派上用场了,下面提供几个关于Oracle性能相关的脚本供大家参考.以下脚本均在Oracle 10g测试通过,Oracle 11g可能要做相应调整. 1.寻找最多BUFFER_GETS开销的SQL 语句 [sql] view plain copy print? --filename: top_sql_by_buffer_gets.sql --Identify heavy SQL (Get the SQL with heavy BUFFER_G

Oracle性能分析10:重建索引续-常用SQL

上一节讲了重建索引的原因和重建方法,这节继续介绍几个常用的SQL语句和存储过程. 查询所有失效的全局索引 select index_name, status from user_indexes where table_name = upper(table_name) and status = 'UNUSABLE' 查询所有失效的分区索引 select index_name, status from user_ind_partitions where index_name in (select i