返回顶部
首页 > 资讯 > 数据库 >怎么理解ORACLE事件跟踪
  • 924
分享到

怎么理解ORACLE事件跟踪

2024-04-02 19:04:59 924人浏览 泡泡鱼
摘要

这期内容当中小编将会给大家带来有关怎么理解oracle事件跟踪,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。ORACLE事件跟踪  Oracle跟踪文件分为三种

这期内容当中小编将会给大家带来有关怎么理解oracle事件跟踪,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

ORACLE事件跟踪

  Oracle跟踪文件分为三种类型:

   1:警告日志文件。记录了数据库启动、运行、关闭时的活动情况。当数据库出现问题时,首先要查看该文件,文件名为alert_sid.log

   2:后台跟踪文件。记录了oracle后台进程的运行状况,名称为sid_processname_processid.trc,存储目录为BACKGROUND_dump_dest

   3:用户跟踪文件。记录了连接到数据库的用户进程的运行信息,名称为SID_ORA_PROCESSID.TRC,存储目录为USER_DUMP_DEST.

  在oracle11g中,这三种文件位于同一目录下:

怎么理解ORACLE事件跟踪

跟踪事件

   设置跟踪事件,会导致oracle将与该事件有关的信息转储到跟踪文件中。依据设置事件的方式,可以将跟踪事件分为2类:PROCESS-EVENT(通过初始化参数文件设置的事件)、SESSioN-EVENT(通过alter session set events或者alter system set events设置的时间)。要使PROCESS-EVENT事件生效,必须重新启动数据库实例,PROCESS-EVENT事件会影响连接到数据库的每一个用户进程。在参数文件中设置多个事件可以采用“:”分隔符,如event="event1:event2:event3"。也可以依次设置多个event,如:

event="event1"

event="event2"

(注意,在event1和event2之间不要存在其他参数,否则只有最后的event即event2生效)。

        对不同的跟踪事件,oracle会产生不同的行为,根据行为的不同,我们大致可以将跟踪事件分为4类:

        1.转储oracle中的某部分内容,如数据块、控制文件内容等。转储活动会在收到跟踪事件命令的同时执行。这类事件不可以通过参数文件进行设置。

        2.跟踪错误信息。设置这类事件,oracle会将特定错误的堆栈信息转储到跟踪文件中。

        3.更改oracle的执行路径。这类事件会影响oracle代码段的执行路径,例如10269事件,会促使smon进程停止对free-space的合并操作。

        4.跟踪进程的相关信息。例如10046事件和10053事件。该类事件会将进程上下文中的特定信息转储到跟踪文件中。

语法格式

        alter system|session set events ‘[eventnumber|immediate]trace nameeventname[forever][, level levelnumber] :  …….’

    通过:符号,可以连续设置多个事件,也可以通过连续使用alter session set events来设置多个事件。

    格式说明:eventnumber指触发dump的事件号,事件号可以是Oracle错误号或oralce内部事件号,内部事件号在10000到10999之间,不能与immediate关键字同用;immediate关键字表示命令发出后,立即将指定的结构dump到跟踪文件中,这个关键字只用在alter session语句中,并且不能与eventnumber、forever关键字同用。trace name是关键字。eventname指事件名称(见后面),即要进行dump的实际结构名。若eventname为context,则指根据内部事件号进行跟踪。forever关键字表示事件在实例或会话的周期内保持有效状态,不能与immediate同用。level为事件级别关键字。但在dump错误栈(errorstack)时不存在级别。levelnumber表示事件级别号,一般从1到10,1表示只dump结构头部信息,10表示dump结构的所有信息。

    对于alter session设置的事件,仅仅只对当前session有效。对于alter system 设置的事件,除对当前session有效外,对新登录的session同样有效,但是对于alter system命令执行之前打开的session是无效的。

IMMEDIATE相关的事件

一.Memory Dumps

1).Global Area 

Alter SESSION SET EVENTS 'immediate trace name global_area level n'; 

1 包含PGA 

2 包含SGA 

4 包含UGA 

8 包含indrect memory

2).Library Cache 

Alter SESSION SET EVENTS 'immediate trace name library_cache level n'; 

1 library cache统计信息 

2 包含hash table histogram 

3 包含object handle 

4 包含object结构(Heap 0)

3).Row Cache 

Alter SESSION SET EVENTS 'immediate trace name row_cache level n'; 

1 row cache统计信息 

2 包含hash table histogram 

8 包含object结构

4).Buffers 

Alter SESSION SET EVENTS 'immediate trace name buffers level n'; 

1 buffer header 

2 level 1 + block header 

3 level 2 + block contents 

4 level 1 + hash chai

5 level 2 + hash chain 

6 level 3 + hash chain 

8 level 4 + users/waiters 

9 level 5 + users/waiters 

10 level 6 + users/waiters

5).Buffer 

Alter SESSION SET EVENTS 'immediate trace name buffer level n'; 

n为某个指定block的rdba,该命令可以转储某个block在buffer中的所有版本。

6).Heap 

Alter SESSION SET EVENTS 'immediate trace name heapdump level level'; 

1 PGA摘要 

2 SGA摘要 

4 UGA摘要 

8 Current call(CGA)摘要 

16 User call(CGA)摘要 

32 Large call(LGA)摘要 

1025 PGA内容 

2050 SGA内容 

4100 UGA内容 

8200 Current call内容 

16400 User call内容 

32800 Large call内容

7).Sub Heap 

oracle 9.0.1版本之前 

Alter SESSION SET EVENTS 'immediate trace name heapdump_addr level n'; 

若n为subheap的地址,转储的是subheap的摘要信息 

若n为subheap的地址+1,转储的则是subheap的内容 

oracle 9.2.0版本之后 

Alter SESSION SET EVENTS 'immediate trace name heapdump_addr level n, addr m'; 

其中m为subheap的地址 

n为1转储subheap的摘要,n为2转储subheap的内容

8).Process State 

Alter SESSION SET EVENTS 'immediate trace name processstate level n';

9).System State 

Alter SESSION SET EVENTS 'immediate trace name systemstate level n';

10).Error State 

Alter SESSION SET EVENTS 'immediate trace name errorstack level n'; 

0 Error stack 

1 level 0 + function call stack 

2 level 1 + process state 

3 level 2 + context area

11).Hang Analysis 

Alter SESSION SET EVENTS 'immediate trace name hanganalyze level n';

12).Work Area 

Alter SESSION SET EVENTS 'immediate trace name workareatab_dump level n'; 

1 SGA信息 

2 Workarea Table摘要信息 

3 Workarea Table详细信息

13).Latches 

Alter SESSION SET EVENTS 'immediate trace name latches level n'; 

1 latch信息 

2 统计信息

14).Events 

Alter SESSION SET EVENTS 'immediate trace name events level n'; 

1 session 

2 process 

3 system

15).Locks 

Alter SESSION SET EVENTS 'immediate trace name locks level n';

16).Shared Server Process 

Alter SESSION SET EVENTS 'immediate trace name shared_server_state level n'; 

n取值为1~14

17).Background Messages 

Alter SESSION SET EVENTS 'immediate trace name bg_messages level n'; 

n为pid+1

二.File Dumps

1).Block 

oracle 7之前 

Alter SESSION SET EVENTS 'immediate trace name blockdump level n'; 

n为block的rdba 

oracle8以后 

Alter SYSTEM DUMP DATAFILE file# BLOCK block#; 

Alter SYSTEM DUMP DATAFILE file# 

BLOCK MIN minimum_block# 

BLOCK MAX maximum_block# 

2).Tree Dump   查看索引的结构

Alter SESSION SET EVENTS 'immediate trace name treedump level n'; 

n为object_id

object_id可以从select object_id from user_objects where object_name = '索引的名字'得到。

3).Undo Segment Header  查看回滚段头部信息

Alter SYSTEM DUMP UNDO_HEADER 'segment_name';

4).Undo for a Transaction 

Alter SYSTEM DUMP UNDO BLOCK 'segment_name' XID xidusn xidslot xidsqn;

5).File Header 

Alter SESSION SET EVENTS 'immediate trace name file_hdrs level n'; 

1 控制文件中的文件头信息

2 level 1 + 通用文件头信息 

3 level 2 + 数据完整文件头信息 

10 level 3

6).Control file 

Alter SESSION SET EVENTS 'immediate trace name controlf level n'; 

1  控制文件中的文件头信息

2  level 1 + 数据库信息 + 检查点信息 

3  level 2 + 可重用节信息 

10 level 3

7).Redo log Header 

Alter SESSION SET EVENTS 'immediate trace name redohdr level n'; 

1  控制文件中的redo log信息 

2  level 1 + 通用文件头信息 

3  level 2 + 完整日志文件头信息 

10 level 3

8).Redo log 

Alter SYSTEM DUMP LOGFILE 'FileName'; 

Alter SYSTEM DUMP LOGFILE 'FileName' 

SCN MIN MinimumSCN 

SCN MAX MaximumSCN 

TIME MIN MinimumTime 

TIME MAX MaximumTime 

LAYER Layer 

OPCODE Opcode 

DBA MIN FileNumber . BlockNumber 

DBA MAX FileNumber . BlockNumber 

RBA MIN LogFileSequenceNumber . BlockNumber 

RBA MAX LogFileSequenceNumber . BlockNumber; 

其中time = (((((yyyy - 1988)) * 12 + mm - 1) * 31 + dd - 1) * 24 + hh) * 60 + mi) * 60 + ss;

 详细内容请看:Http://blog.csdn.net/yidian815/article/details/12568027

9).Loghist 

Alter SESSION SET EVENTS 'immediate trace name loghist level n'; 

n=1 dump控制文件中最早和最迟的日志历史项 

n>1 dump 2^n个日志历史项

获取诊断事件号

   大部分的诊断事件的数值都是在10000至10999范围内,使用如下的脚本可以查看到所有的诊断事件:

[sql

SET SERVEROUTPUT ON  

  DECLARE   

  err_msg VARCHAR2(120);  

  BEGIN  

  dbms_output.enable (1000000);  

  FOR err_num IN 10000..10999  

  LOOP  

  err_msg := SQLERRM (-err_num);  

  IF err_msg NOT LIKE '%Message '||err_num||' not found%' THEN  

  dbms_output.put_line (err_msg);  

  END IF;  

  END LOOP;  

 END;  

  / 

上述就是小编为大家分享的怎么理解ORACLE事件跟踪了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么理解ORACLE事件跟踪

本文链接: https://lsjlt.com/news/65993.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么理解ORACLE事件跟踪
    这期内容当中小编将会给大家带来有关怎么理解ORACLE事件跟踪,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。ORACLE事件跟踪  Oracle跟踪文件分为三种...
    99+
    2024-04-02
  • oracle跟踪常用内部事件号
    Oracle内部事件号,常被用来跟踪系统状态,怎样使用这些内部事件号,是需要事件和经验的。在此仅记录这些常用的内部事件号,为工作准备。 1、10013...
    99+
    2024-04-02
  • 使用Oracle跟踪文件的问题详解
    一、什么是跟踪文件? 跟踪文件中包含了大量而详细的诊断和调试信息。通过对跟踪文件的解读和分析,我们可以定位问题、分析问题和解决问题。从跟踪文件的产生的来源来看,跟踪文件又可以分为两类...
    99+
    2024-04-02
  • git怎么删除未跟踪文件
    要删除未跟踪的文件,可以使用以下命令: `git clean`: 该命令用于从工作目录中删除未跟踪的文件。 `git clea...
    99+
    2023-10-26
    git
  • 详解Oracle块修改跟踪功能
    块修改跟踪功能是指使用二进制文件记录数据库中数据库更改的过程。 其目的是提高增量备份操作的性能,因为RMAN可以使用快修改跟踪文件找到上次执行备份操作后被修改的数据块。这可以节省大量...
    99+
    2024-04-02
  • 【赵强老师】使用Oracle的跟踪文件
    一、什么是跟踪文件? 跟踪文件中包含了大量而详细的诊断和调试信息。通过对跟踪文件的解读和分析,我们可以定位问题、分析问题和解决问题。从跟踪文件的产生的来源来看,跟踪文件又可以分为两类:一类是数据库的操作人员有意生成的;另一类则是由于出现...
    99+
    2015-04-22
    【赵强老师】使用Oracle的跟踪文件
  • SQL中如何利用10046事件扩展SQL跟踪
    这篇文章将为大家详细讲解有关SQL中如何利用10046事件扩展SQL跟踪,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在会话sql_trace的基础上,利用10046诊断...
    99+
    2024-04-02
  • 数据库中如何使用10046事件跟踪SQL
    这篇文章主要介绍数据库中如何使用10046事件跟踪SQL,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!10046 事件概述 这是一个特殊的事件,可以被用来发起sql_trace类的...
    99+
    2024-04-02
  • git中怎么设置跟踪
    Git 是当今最流行的版本控制工具之一,大量的程序员、开发人员和团队都在使用它来管理他们的项目。Git 提供了许多功能和命令来方便地管理代码库及其修改,其中一个很有用的功能是 Git 跟踪。Git 跟踪能让你设置版本控制系统跟踪你的文件,可...
    99+
    2023-10-22
  • 如何利用errorstack事件进行错误跟踪和诊断
    这篇文章主要为大家展示了“如何利用errorstack事件进行错误跟踪和诊断”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何利用errorstack事件进行错...
    99+
    2024-04-02
  • 怎么理解oracle等待事件enq
    这篇文章主要讲解了“怎么理解oracle等待事件enq”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解oracle等待事件enq”吧!Enqueue ...
    99+
    2024-04-02
  • windowsserver2019关机重启问原因解决方法(关闭事件跟踪程序)
    最近为了学习windows server 2019 服务器,每次关闭重启都要提示,因为是个人使用不是当服务器所以还是给取消了,下面就给出具体的解决方法 问:每次关闭重启都会如下提示 ...
    99+
    2023-05-17
    win2019 关闭事件跟踪程序
  • SQLServer中怎么控制跟踪标记
    这篇文章给大家介绍SQLServer中怎么控制跟踪标记,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。跟踪标记是什么?对于DBA来说,掌握Trace Flag是一个成为SQL Serve...
    99+
    2024-04-02
  • 怎么跟踪Microsoft Excel中的更改
    这篇文章主要介绍了怎么跟踪Microsoft Excel中的更改的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么跟踪Microsoft Excel中的更改文章都会有所收获,下...
    99+
    2023-04-21
    excel
  • SAP CRM One Order跟踪怎么实现
    本篇内容介绍了“SAP CRM One Order跟踪怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事务码CRMD_TRACE_SE...
    99+
    2023-06-04
  • go micro怎么集成链路跟踪
    本文小编为大家详细介绍“go micro怎么集成链路跟踪”,内容详细,步骤清晰,细节处理妥当,希望这篇“go micro怎么集成链路跟踪”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。opent...
    99+
    2023-06-30
  • 我的柜子好像动了之鼠标跟踪事件教程
    目录鼠标跟踪事件测试代码分析盒子跟着鼠标各自转起来具体实现步骤源码鼠标跟踪事件测试 不知道你们知不知道这个梗。等一下,我的柜子好像动了。或者换个内容,这个摄像头Moses好像一直在看...
    99+
    2023-05-19
    柜子动了鼠标跟踪事件 鼠标跟踪事件教程
  • gomicro集成链路跟踪的方法和中间件原理解析
    目录链路跟踪实战安装zipkin程序结构安装依赖包编写服务端编写客户端Wrap原理分析服务端WrapHandlerWrapperWrap Handler客户端WrapXXXWrapp...
    99+
    2024-04-02
  • python实时目标跟踪怎么实现
    这篇“python实时目标跟踪怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python实时目标跟踪怎么实现”文章吧...
    99+
    2023-07-05
  • 亚马逊跟踪服务器怎么用
    打开亚马逊AWS管理控制台。 在控制台中选择您要跟踪的服务器。 点击“Start server”按钮以启动跟踪服务器。 在服务器启动后,您可以通过“Connect”按钮登录到跟踪服务器。 在登录后,您可以设置跟踪服务器的配置。例如,您可以...
    99+
    2023-10-27
    亚马逊 服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作