Oracle的跟踪文件(trace file)
跟踪文件通常都是因为通过DBMS_MONITOR(在Oracle Database 9i Relese 2)及更早版本中则是ALTER SESSION SET SQL_TRACE=TRUE启用了跟踪的结果,或者是通过10046事件使用扩展的跟踪工具生成的,如下
这些跟踪文件包含与诊断和性能有关的信息。它们对于了解数据库应用的内部工作有着非凡的意义。在一个正常运行的数据库中,你会经常看到这些跟踪文件,而且远比看到其他类型的跟踪文件多得多。
1 文件位置
不论是使用DBMS_MONITOR、SQL_TRACE还是扩展的跟踪工具,Oracle都会在数据库服务器主机的以下两个位置生成一个跟踪文件。
如果使用专用服务器连接,会在user_dump_dest参数指定的目录中生成跟踪文件。
如果使用共享服务器连接,则会在background_dump_dest参数指定的目录中生成跟踪文件。
注意:11g版本中background_dump_dest和user_dump_dest参数将要被废弃掉,虽然还可以使用这两个参数进行查询但可以使用使用新的参数或视图进行查询。
使用show parameter dump_dest命令来查看目录,也可以直接查询V$PARAMETER视图,或查询新的V$DIAG_INFO 视图。
V$DIAG_INFO是Oracle Database 11g新增的视图,这在较早的版本中还没有。它是访问新增ADR工具所用跟踪信息的一个更容易的接口。
Oracle Database 11g调整了很多文件的默认存储位置,使它们组织得更好一些,从而能更容易地记录对Oracle的服务请求。其中最重要的行包括下面两项:
Diag Trace:这是Oracle Database 11g中跟踪文件(包括后台和用户转储目标)所在的位置。
Default Trace File:这是当前会话的跟踪文件名。在较早的版本中,这个文件名可能很难得到。在Oracle Database 11g中,只需要对V$DIAG_INFO简单的查询就可以返回这个文件的完全限定文件名。
2命名约定
Oracle中跟踪文件的命名约定总在变化,示例如下:
跟踪文件名 | 数据库版本 |
ora_10583.trc | 9i Release 1 |
ora9ir2_ora_1905.trc | 9i Release 2 |
ora10gr2_ora_6793.trc | 10g Release 2 |
ora11gr2_ora_1990.trc | 11g Release 2 |
跟踪文件名可以分为以下几个部分。
文件名的第一部分是ORACLE_SID(但9i Release 1例外)
文件名的下一部分只有一个ora。
跟踪文件名中的数字是专用服务器的进程ID,可以从V$PROCESS视图得到。
Oracle Database 11g能方便使用V$DIAG_INFO视图,在该版本之前,实际(假设使用专用服务器模式)需要访问4个视图。
V$PARAMETER:找到USER_DUMP_DEST指定的跟踪文件位置,找到可能在跟踪文件名中用到的可选的tracefile_identifier。
V$PROCESS:查找进程ID。
V$SESSION:正确地标识其他视图中的会话信息。
V$INSTALCE:得到ORACLE_SID。
使用下面的查询可以生成跟踪文件名:
SELECT C.VALUE || '/' || D.INSTANCE_NAME || '_ora_' || A.SPID || CASE
WHEN E.VALUE IS NOT NULL THEN
'_' || E.VALUE
END || '.trc' TRACE
FROM V$PROCESS A, V$SESSION B, V$PARAMETER C, V$INSTANCE D, V$PARAMETER E
WHERE A.ADDR = B.PADDR
AND B.SID = USERENV('sid')
AND C.NAME = 'user_dump_dest'
AND E.NAME = 'tracefile_identifier';
如果文件存在就可以通过名字访问它。只有在启用跟踪后才能出现跟踪文件。在Windows平台上要把/换成\。
3 对跟踪文件加标记
有一种办法可以对跟踪文件“加标记”,这样即便无权访问V$PROCESS和V$SESSION,也能找到跟踪文件。假设你能读取user_dump_dest目录,就可以使用会话参数tracefile_identifier。采用这种方法可以为跟踪文件名增加一个可以唯一标识的串:
可以看到,跟踪文件还是采用标准的<ORACLE_SID>_ora_<PROCESS_ID>格式命名,但是这里还有为它指定的唯一的串,这样就能很容易找到跟踪文件名。