DB Cache

时间:2022-04-22
本文章向大家介绍DB Cache,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1 DB Cache 是以bock为单位组织的缓冲区,不同大小的BLOCK对应不同的缓冲区参数

2 DB Cache的命中率越高,访问性能就越好

3 Cache中的数据块通过散列算法实现

4 每个链上的buffers数量,最佳的情况是每个链上只有一个buffer

5 DBWR进程控制脏数据写入

6 在DB Cache,同一个数据块中可能存在多个版本的数据

7 大表的扫描,热块冲突都可能导致闩锁的争用

引入tch计数器,避免LRU链上频繁移动

LRU链上搜索达到最大深、LRU-W上没有足够的clean buffers都会触发标记位,使得DBWR进程讲脏数据写入磁盘

几个重要的数据链:

1 LRU list普通的LRU链

2 LRU-AUX list 被确认的clean的链,包括DBWR已经写回文件的 数据块和干净快

3 LRU-XO list 重用对象链

4 LRU-XR list CKPT搜索这些BUFFER,将脏数据写入该链,再由DBWR写入磁盘

闩锁争用:

1 热块冲突

2 数据库在某个时间段出现大量的数据块扫描、热链

使用keep pool存放大表,可以降低物理读,改善cache命中率

使用owi观点和时间模型分析,帮助分析数据库性能

DB cache命中率低,意味着更多的物理IO、更多的闩锁使用、较低的效率。RAC中,更多的实例间通信消息

DB cache调优,注意 free buffere waits writes complete waits两个性能指标