加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

关于Oracle数据库Kfk: Async Disk IO等待事件深度解析

发布时间:2019-08-30 01:06:18 所属栏目:MySql教程 来源:波波说运维
导读:副标题#e# 概述 一大早运维团队就来找事,说系统又有点卡了,然后发现了一个比较少见的等待事件--kfk: async disk IO,趁着这次排查的过程也简单说下这个等待事件吧! 1、查看TOP N等待事件 SELECTinst_id,EVENT,SUM(DECODE(WAIT_TIME,0,0,1))Prev,SUM(DECOD
副标题[/!--empirenews.page--]

 概述

一大早运维团队就来找事,说系统又有点卡了,然后发现了一个比较少见的等待事件--kfk: async disk IO,趁着这次排查的过程也简单说下这个等待事件吧!

关于Oracle数据库Kfk: Async Disk IO等待事件深度解析

1、查看TOP N等待事件

  1. SELECT inst_id,EVENT, SUM(DECODE(WAIT_TIME, 0, 0, 1)) "Prev", SUM(DECODE(WAIT_TIME, 0, 1, 0)) "Curr", COUNT(*) "Tot" ,  
  2. sum(SECONDS_IN_WAIT) SECONDS_IN_WAIT 
  3. FROM GV$SESSION_WAIT 
  4. WHERE event NOT 
  5. IN ('smon timer','pmon timer','rdbms ipc message','SQL*Net message from client','gcs remote message') 
  6. AND event NOT LIKE '%idle%' 
  7. AND event NOT LIKE '%Idle%' 
  8. AND event NOT LIKE '%Streams AQ%' 
  9. GROUP BY inst_id,EVENT 
  10. ORDER BY 1,5 desc; 
  11. --class slave wait 

关于Oracle数据库kfk: async disk IO等待事件深度解析

可以发现排在前面的是kfk: async disk IO等待事件。

2、根据等待事件查会话

  1. SELECT /*+rule */ sid, s.serial#, spid, event, sql_id, seconds_in_wait ws, row_wait_obj# obj, 
  2. s.username, s.machine, BLOCKING_INSTANCE||'.'||blocking_session b_sess  
  3. FROM v$session s, v$process p  
  4. WHERE event='&event_name' AND s.paddr = p.addr order by 6; 
关于Oracle数据库kfk: async disk IO等待事件深度解析

3、查询某个会话详情

  1. SELECT /*+rule */ sid, s.serial#, spid, event, sql_id, seconds_in_wait ws, row_wait_obj# obj, 
  2. s.username, s.machine, BLOCKING_INSTANCE||'.'||blocking_session b_sess  
  3. FROM v$session s, v$process p  
  4. WHERE event='&event_name' AND s.paddr = p.addr order by 6; 

显示在备份..

关于Oracle数据库kfk: async disk IO等待事件深度解析
关于Oracle数据库kfk: async disk IO等待事件深度解析

4、检查服务器是否在备份?

查看备份日志发现确实是正在做0级全备。

关于Oracle数据库kfk: async disk IO等待事件深度解析

5、查看kfk: async disk IO

  1. select name,parameter1,parameter2,parameter3,wait_class from v$event_name where name='kfk: async disk IO'; 
关于Oracle数据库kfk: async disk IO等待事件深度解析

6、关于kfk: async disk IO

kfk: async disk IO等待事件是ASM下异步的System I/O等待事件,kfk内核层面在disk_asynch_io=true时被激活。当rbal或其他ASM相关后台进程在维护ASM磁盘组时可能进入kfk: async disk IO等待。

先确定一点,kfk: async disk IO是11G后ASM下直接路径操作和ASM维护操作时会遇到的一个等待事件。

先来看大牛的描述吧:

关于Oracle数据库kfk: async disk IO等待事件深度解析

异步IO的两个函数:io_submit和io_getevents,Oracle是先调用io_submit发起异步IO,然后调用io_getevents查看IO状态。

从图中可以看到,这位大牛认为,io_submit阶段,等待是kfk: async disk IO, 从io_getevents到IO完成,是direct path read。

再来看看紧接着的下幅图:

关于Oracle数据库kfk: async disk IO等待事件深度解析

在这幅图中,这位大师打开10046,并同时用Truss、Strace类的工具跟踪进程的执行,跟踪结果中,先有io_submit调用,马上就是向10046跟踪文件中写kfk: async disk IO等待。在io_getevents调用后,又紧接着是向10046跟踪文件中写direct path read等待事件。据此,此大师得出结论,io_submit期间,等待事件是kfk: async disk IO,io_getevents则对应direct path read。

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读