ORACLE之读不堵塞写分析,---buffer busy waits

1 抬高水位点,减少buffer busy waits


2 日志写性能低导致大量的buffer busy waits,

修改一个buffer步骤:

1 申请独享cbc latch,遍历 buffer chain查找到buffer bh。

2 在cbc保护表修改buffer pin锁为X。

3 释放cbc lach。生成redo 数据。

4 修改buffer内容。

5 申请cbc latch ,修改buffer pin锁。

6 释放独占的X buffer pin锁。

7 释放cbc latch。


3 优化逻辑度较大的语句。


2 ORACLE之读不堵塞写分析

A进程读取5号文件的1234数据块,B进程需要修改5号文件1234数块,过程分析如下:

ORACLE之读不堵塞写分析,---buffer busy waits

ORACLE之读不堵塞写分析,---buffer busy waits

ORACLE之读不堵塞写分析,---buffer busy waits

ORACLE之读不堵塞写分析,---buffer busy waits

ORACLE之读不堵塞写分析,---buffer busy waits

ORACLE之读不堵塞写分析,---buffer busy waits

如果此时有进程C 需要读取5号文件的1234块,就需要进行等待,---buffer busy waits,操作单位为(以块为单位)