数据库缓冲区缓存(database buffer cache)
BUFFER CACHE:
作用:用于缓存数据物理磁盘上的磁盘块,从而加快对磁盘上数据的访问。
组成:
Keep pool : 缓存那些需要经常查询但是又容易被默认缓冲区置换出去的对象,数据读取到keep pool中,会一直保留在内存 中,不会被刷新出去,比如整天频繁使用的表,放在保留池中,能够有效的减少物理IO。
Recycle pool : 回收池与保留池正好相反,用于缓存临时使用的,不被经常使用的较大的对象,把这些段与保持池和默认池 中的段分开,防止保持池和默认池中的数据由于老化而退出缓存。
Default pool : 当没有指定时,数据就会放在默认池中,也就是说,放在默认池的数据利用的是LRU机制,指定DEFAULT将 适用默认的缓冲池。这个选项适用于没有分配给KEEP缓冲池和RECYCLE缓冲池的其它数据库对象。
(10g中sga自动管理,ORACLE只会帮助我们管理default pool)
buffer状态:
0.free
1.xcur 当前正在被使用,在单实例数据库中current块就等于xcurrent块
2.scur 在多实例数据库RAC环境中才会出现scurrent块
3.cr 为了保证读一致性而使用undo空间构造的块
4.read 正在从磁盘里读入buffer中的块
5.mrec 进行media recovery时所生成的块
6.irec 进行instance recovery时所生成的块
7.write 通过DBWn从buffer中写入磁盘数据文件中的块
读方式:
逻辑读:存在缓存
物理读:发生物理I0消耗资源
【注】:①查询buffer cache中有多少buffer的语句 select count(*) from x$bh;