Oracle等待事件内容详解

1.1 等待事件主要可以分为两类,即空闲(IDLE)等待事件和非空闲(NON-IDLE)等待事件。
1). 空闲等待事件指Oracle正等待某种工作,在诊断和优化数据库的时候,不用过多注意这部分事件。
2). 非空闲等待事件专门针对ORACLE的活动,指数据库任务或应用运行过程中发生的等待,这些等待事件 是在调整数据库的时候需要关注与研究的。

在Oracle 10g中的等待事件有872个,11g中等待事件1116个。 我们可以通过v$event_name 视图来查看等待事件的相关信息。

1.2 查看v$event_name视图的字段结构
SQL> desc v$event_name;
名称                    是否为空    类型
-------------------   --------------- --------
EVENT#                       NUMBER
EVENT_ID                      NUMBER
NAME                         VARCHAR2(64)
PARAMETER1                  VARCHAR2(64)
PARAMETER2                  VARCHAR2(64)
PARAMETER3                  VARCHAR2(64)
WAIT_CLASS_ID               NUMBER
WAIT_CLASS#                NUMBER
WAIT_CLASS                  VARCHAR2(64)

1.3 查看等待事件分类情况
  SELECT

      wait_class#,

  wait_class_id,
            wait_class,
            COUNT ( * ) AS "count"
  FROM  v$event_name
  GROUP BY  wait_class#, wait_class_id, wait_class
  ORDER BY  wait_class#;

WAIT_CLASS#   WAIT_CLASS_ID   WAIT_CLASS                count
-----------     -------------      --------------------     ----------
        0        1893977003       Other                        717
        1        4217450380       Application                    17
        2        3290255840       Configuration                24
        3        4166625743       Administrative              54
        4        3875070507       Concurrency                  32
        5        3386400367       Commit                        2
        6        2723168908       Idle                              94
        7        2000153315       Network                        35
        8        1740759767       User I/O                        45
        9        4108307767       System I/O                  30
        10       2396326234        Scheduler                      7
        11       3871361733        Cluster                          50
        12       644977587        Queueing                      9

1.4 相关的几个视图
V$SESSION:代表数据库活动的开始,视为源起。
V$SESSION_WAIT:视图用以实时记录活动SESSION的等待情况,是当前信息。
V$SESSION_WAIT_HISTORY:是对V$SESSION_WAIT的简单增强,记录活动SESSION的最近10次等待。
V$SQLTEXT:当数据库出现瓶颈时,通常可以从V$SESSION_WAIT找到那些正在等待资源的SESSION,
通过SESSION的SID,联合V$SESSION和V$SQLTEXT视图就可以捕获这些SESSION正在执行的SQL语句。
V$ACTIVE_SESSION_HISTORY:是ASH的核心,用以记录活动SESSION的历史等待信息,每秒采样一次,这部分内容记录在内存中,期望值是记录一个小时的内容。
WRH#_ACTIVE_SESSION_HISTORY: 是V$ACTIVE_SESSION_HISTORY在AWR的存储地。
V$ACTIVE_SESSION_HISTORY中 的信息会被定期(每小时一次)的刷新到负载库中,并缺省保留一个星期
用于分析。
DBA_HIST_ACTIVE_SESS_HISTORY:视图是WRH#_ACTIVE_SESSION_HISTORY视图和其他几个视图的联合展现,通常通过这个视图进行历史数据的访问。
V$SYSTEM_EVENT: 由于V$SESSION记录的是动态信息,和SESSION的生命周期相关,而并不记录历史信
息,所以ORACLE提供视图V$SYSTEM_EVENT来记录数据库自启动以来所有等待事件的汇总信息。通过这个视图,用户可以迅速获得数据库运行的总体概况。

1.5 等待事件相关查询

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/bb429c7016f2649dda92bb5d118c759f.html