wait events研究之"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管理,如果不行,考虑扩展回滚段。