oracle非空闲等待事件
程序员文章站
2022-05-07 10:34:23
...
oracle非空闲等待事件 已上传
摘录
- 事件参数说明:
事件号 |
事件名 |
参数一 |
参数二 |
参数三 |
145 |
buffer busy waits |
file# |
block# |
9i - 原因码 10g - block class# |
- ORACLE会话正在等待PIN住一个缓冲区,会话必须在读取或修改缓冲区之前将该缓冲区PIN住。
- 在任何时侯只有一个进程可以PIN住一个缓冲区。
- buffer busy waits表明读/读、读/写、写/写争用。
- 根据P3中指明的原因码有不同的处理方式。
- 现象描述:会话在SGA中读取或修改缓冲区之前,必须要先获取cahce buffers chains锁存器,获取后然后遍历这个缓冲区链,直到发现它需要的缓冲区头。然后以共享方式或独占方式获取该缓冲区锁或缓冲区头部的PIN,一旦缓冲区被PIN住,会话即释放cache buffers chains锁存器。如果无法获得PIN,会话就在buffer busy waits等待事件上等待。
- 该事件只与SGA中缓冲区相关,与会话私有的PGA中执行的读/写操作无关。
- 处理该等待事件时主要注意以下四方面:
1) 该等待事件主要的原因码是什么?(参数P3)
2) buffer busy waits事件需要的块类?(由P1即可找出等待块的类列)
3) 缓冲区所属的段(由P1和P2参数配合视图v$extents即可找出等待块的所属段)
select s.segment_name, s.partition_name
from dba_extents s
where <P2的值> between s.block_id and (s.block_id + s.blocks -1) and s.file_id = <P1的值>
4) 和buffer busy waits事件相关的SQL语句