共计 2145 个字符,预计需要花费 6 分钟才能阅读完成。
跟踪文件通常都是因为通过 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> 格式命名,但是这里还有为它指定的唯一的串,这样就能很容易找到跟踪文件名。
参考:Oracle Database 9i/10g/11g 编程艺术:深入数据库体系结构(第 2 版)PDF 下载见 http://www.linuxidc.com/Linux/2016-02/128078.htm
更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/143981.htm