buffer cache的组成及剖析

                                             数据库缓冲区缓存(database buffer cache)


BUFFER CACHE:

作用:用于缓存数据物理磁盘上的磁盘块,从而加快对磁盘上数据的访问。

组成:  

Keep     pool : 缓存那些需要经常查询但是又容易被默认缓冲区置换出去的对象,数据读取到keep pool中,会一直保留在内存                                     中,不会被刷新出去,比如整天频繁使用的表,放在保留池中,能够有效的减少物理IO。      

Recycle pool : 回收池与保留池正好相反,用于缓存临时使用的,不被经常使用的较大的对象,把这些段与保持池和默认池                                      中的段分开,防止保持池和默认池中的数据由于老化而退出缓存。

Default  pool 当没有指定时,数据就会放在默认池中,也就是说,放在默认池的数据利用的是LRU机制指定DEFAULT将                                                                  适用默认的缓冲池。这个选项适用于没有分配给KEEP缓冲池和RECYCLE缓冲池的其它数据库对象。

                       (10gsga自动管理,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 通过DBWnbuffer中写入磁盘数据文件中的块

读方式:

                逻辑读:存在缓存

                物理读:发生物理I0消耗资源

【注】:①查询buffer cache中有多少buffer的语句 select count(*) from x$bh;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值