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两个性能指标

最后修改:2022 年 01 月 29 日
如果觉得我的文章对你有用,请随意赞赏