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两个性能指标
posted @ 2014-01-13 12:47 xingoo 阅读(...) 评论(...) 编辑 收藏