wait events研究之"buffer busy waits"

时间:2022-02-28 19:27:48
    buffer busy wait是在多个进程尝试访问同一buffer时出现的较常见的等待事件,按buffer类型分为四种:data block, segment header, undo header, undo block。确定访问哪个对象时出现buffer busy waits事件,可通过下面的方法进行定位:

SELECT owner, object_name, subobject_name, object_type
FROM DBA_OBJECTS WHERE data_object_id in (SELECT row_wait_obj# FROM V$SESSION WHERE

EVENT = 'buffer busy waits';

 

1、segment header冲突

一般是由于free list冲突引起。可以通过如下方式查看segment的设置:

SELECT SEGMENT_NAME, FREELISTS FROM DBA_SEGMENTS WHERE SEGMENT_NAME = segment name
AND SEGMENT_TYPE = segment type;

解决segment header冲突,可考虑能否将segment管理调整为assm方式,如果不行,建议增加segment上freelist及freelist groups。

 

2、data block冲突

由于多个进程尝试同时写入table或index上的同一block引起的冲突。解决方法仍然建议采用assm,或增减freelist。

 

3、undo header

回滚段头上的冲突,建议采用auto undo管理,如果不行,考虑增加回滚段数量。

 

4、undo block

回顾段上的冲突, 建议采用auto undo管理,如果不行,考虑扩展回滚段。