7.Oracle之等待事件

1. Oracle的等待事件

  Oracle的等待事件主要可以分为两类:即空闲(IDLE)和非空闲(NON-IDLE)等待

  • 空间等待事件是指Oracle等待某种工作,在诊断和优化数据库的时候,不用过多注意
  • 非空闲等待事件是专门针对oracle的活动,指数据库任务或应用运行过程中发生的等待,这些等待事件是在调整数据库库的时候需要关注和研究的。在10g中等待事件有872个,11g等待事件1116个,可以通过v$event_name视图来查看等待事件的相关信息。
SQL>  select name from v$event_name where rownum<10;

NAME
----------------------------------------------------------------
null event
logout restrictor
VKTM Logical Idle Wait
VKTM Init Wait for GSGA
IORM Scheduler Slave Idle Wait
acknowledge over PGA limit
Parameter File I/O
rdbms ipc message
remote db operation

2.Oracle等待事件的相关视图

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来记录数据库自启动以来所有等待事件的汇总信息。通过这个视图,用户可以迅速获得数据库运行的总体概况。

v$session_event : 这个可以查看会话所有的等待信息

3.查看某个会话中的等待事件

SQL> select distinct sid from v$mystat;   #1.查看当前会话的sid
 
       SID
----------
       422

SQL> select sid,event,state from v$session where sid=422;   # 2.根据sid查看该会话的等待事件

       SID EVENT                          STATE
---------- ------------------------------ -------------------
       422 SQL*Net message from client    WAITING

也可以通过视图v$session_wait查看

SQL> select  SID,event,WAIT_CLASS from v$session_wait where sid=422;

       SID EVENT                          WAIT_CLASS
---------- ------------------------------ ------------------------------
       422 SQL*Net message from client    Idle

4.常见的IO等待事件

  4.1 ilde wait event(空闲等待) 

       1.由于进程无事可做,等待分派任务

     2.空等待意味着空闲

       3.空闲, 还意味着其它的事情...

    

  4.2 db file scattered read(随机读)

    当数据库以多数据块读入sga时(一般在fts(full table scan),iffs(index fast full scan)会发生)

      解决:1. 无需解决  2.考虑索引  3.考虑并行

  4.3 db file sequential read(顺序读)

   当把一个数据块读入sga时,发生db file sequential等待,一般会在用索引时会发生该事件。

     解决:1. 无需解决  2.sql语句是否有问题  3.考虑其他索引(符合索引或者位图索引或者全文索引) 4. 全表扫描+并行  5. 改善磁盘I/O

  4.4 direct path read

      数据被直接读物到pga内存中时,发生的等待

    - 排序数据由于内存不足,被写到磁盘上(temp表空间数据文件),然后重新读取时

          - 并行操作的slave进程的数据读取

          - 其它的属于某个会话私有数据的读取操作。

      参数: file# : 读取的文件ID      block#: 等待要读取的数据块ID     blocks: 读取的数据块的数量

          解决:1. 无须解决  2. 增大内存排序区(pag)  3. 调整操作的并行度  4. 改善磁盘的I/O

 4.5 direct path write

     数据从PGA内存中直接写到磁盘上,发生的等待

    - 排序数据由于内存不足,被写到磁盘上(temp表空间数据文件),然后重新读取时

          - 并行操作的slave进程向磁盘上写数据。。

          - 其它的属于某个会话私有数据的读取操作。

   4.6 Log file sync

     用户commit(rollback)时,lgwr需要将log buffer的数据写入到log file上面,发生的等待

   解决: 1. 减少commit的频率   2. 提高I/O性能 

5 常见的内存的等待事件

 5.1 buffer busy waits

    内存中对相同的数据库多个并发请求时,导致这个等待

   解决:热块

   5.2 free buffer waits

    server process 无法找到一个可用的内存空间

    - 系统I/O成为瓶颈(或者性能不够)

        - 等待资源latch争用

        - SGA太小

        解决:1 优化I/O 增高I/O通道的性能  异步I/O  增加多个dbwr进程  2. 增大SGA

 

参考:https://zhuanlan.zhihu.com/p/64300823

   https://blog.csdn.net/qq_69462005/article/details/124158912

         https://blog.csdn.net/m0_50880099/article/details/121742337

posted on 2023-01-08 14:54  太白金星有点烦  阅读(300)  评论(0编辑  收藏  举报

导航