本文主要是介绍oracle-检查点队列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
检查点队列也在buffer cache上,和LRU,CBC。。。一样,也在一个链上。
检查点队列链也链的是脏块,也就是脏块不仅链在LRUW上,也在这里。
在LRUW上是按照冷热排列。而检查点队列链是按照脏块的第一次脏的时间顺序排序。
RBA:日志地址块
LRBA:第一次被脏的日志地址
HRBA:最后一次被脏的日志地址
on disk RBA:写入的最后一条日志的地址,最新的地址
脏块中都有LRBA和HRBA
CKPT进程
分为两种工作方式
完全检查点:通过DBWR进程将所有脏块完全写入磁盘,例如数据库关闭前。
增量检查点:每隔三秒发生一次,将检查点队列的最早脏块所对应的LRBA地址记录到控制文件中。
实例崩溃恢复的时候,使用redolog,终点的日志是最新的,起点的是LRBA地址的日志,是从控制文件中找到的,所以就用这一段区间的日志恢复脏块,里面的未提交的事务通过undo回滚。
所以如果没有检查点队列,如果想恢复的话,就只能用所有的redolog进行恢复,速度慢。所以总结,检查点队列其实是加快实例崩溃恢复的。8g之前就没有
这篇关于oracle-检查点队列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!