首页 > 数据库 >7.Oracle之等待事件

7.Oracle之等待事件

时间:2023-01-08 15:00:47浏览次数:59  
标签:视图 SESSION 事件 SQL Oracle 等待 HISTORY

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

标签:视图,SESSION,事件,SQL,Oracle,等待,HISTORY
From: https://www.cnblogs.com/zmc60/p/17034679.html

相关文章

  • C# Oracle海量数据瞬间插入到数据库的方法
    转自:https://www.cnblogs.com/gaoyuanzhen/p/3875806.htmlC#海量数据瞬间插入到数据库的方法当我们在数据库中进行大量的数据追加时,是不是经常因为数据量过大而苦恼呢?而......
  • 节流 频繁触发事件只执行一次 必须要等当前事件结束了 才能被再次触发
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><metaname="viewport"content="widt......
  • 防抖就是在事件在同一时间内多次触发只执行最后一次 比如你设置1000毫秒定时,但是在500
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><metaname="viewport"content="widt......
  • 事件
    事件分为:冒泡事件、隧道事件、和直接事件隧道事件名称始终以Preview开头并首先引发。这使目标元素的父元素有机会在事件到达子元素之前看到它(因此有Preview前缀)。隧道预......
  • oracle在线增加redo日志组成员
    文档课题:oracle在线增加redo日志组成员.数据库:oracle11.2.0.41、相关知识oracle通过redo保证数据库事务可以被重演,从而使得在发生故障之后,数据可以被恢复.redo对于oracle数......
  • 事件循环
    进程和线程进程:计算机运行的程序,操作系统管理程序的一种方式线程:运行调度的最小单位,被包含在进程中浏览器的事件循环1.JavaScript是单线程的,但JavaScript的线程应该......
  • 使用KVM克隆用于Oracle DB的主机
    首先,通过现有的vm1「在上篇文章使用KVM创建OEL虚拟机已创建」克隆出一个vm,名字叫做db1,然后修改一些配置,使其更适用于OracleDB的主机。1.通过克隆vm1生成db12.解决vir......
  • Vue自定义事件原理
    自定义事件的基本用法<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><metaname="viewport"content="width=device-width,initial-sca......
  • Oracle官网下载MySql
    第一步:进入Oracle官网地址第二步:在Products中点击MySQL   第三步:点击DOWNLOADS第三步:点击MySQLCommunity(GPL)Downloads  第四步:点击MySQLCommunitySe......
  • Spring5 IOC容器解析——事件监听机制
    一、事件驱动模型简介事件驱动模型,也即是我们通常说的观察者。基于发布-订阅模式的编程模型。概念定义对象间的一种一对多的依赖关系,当一个对象的状态发生变化时,所有依赖......