wait events研究之"buffer busy waits"

   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管理,如果不行,考虑扩展回滚段。

转载于:https://www.cnblogs.com/rootq/archive/2009/04/18/1438470.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值