oracle-检查点队列

检查点队列也在buffer cache上,和LRU,CBC。。。一样,也在一个链上。
检查点队列链也链的是脏块,也就是脏块不仅链在LRUW上,也在这里。
在LRUW上是按照冷热排列。而检查点队列链是按照脏块的第一次脏的时间顺序排序。
RBA:日志地址块
LRBA:第一次被脏的日志地址
HRBA:最后一次被脏的日志地址
on disk RBA:写入的最后一条日志的地址,最新的地址
脏块中都有LRBA和HRBA

CKPT进程
分为两种工作方式
完全检查点:通过DBWR进程将所有脏块完全写入磁盘,例如数据库关闭前。
增量检查点:每隔三秒发生一次,将检查点队列的最早脏块所对应的LRBA地址记录到控制文件中。

实例崩溃恢复的时候,使用redolog,终点的日志是最新的,起点的是LRBA地址的日志,是从控制文件中找到的,所以就用这一段区间的日志恢复脏块,里面的未提交的事务通过undo回滚。
所以如果没有检查点队列,如果想恢复的话,就只能用所有的redolog进行恢复,速度慢。所以总结,检查点队列其实是加快实例崩溃恢复的。8g之前就没有

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值