第十八讲--检查点队列(checkpoint queue)

本文详细介绍了Oracle数据库中的检查点队列,包括其作用、脏块管理、LRBA和HRBA概念,以及CKPT进程的工作方式,如完全检查点和增量检查点。检查点队列有助于维护数据一致性,并在数据库关闭时确保所有脏块被写回磁盘。
摘要由CSDN通过智能技术生成


Buffer cache的左边是buffer右边是链,用来记录buffer。

链的类型有LRU、LRUW。LRU是将干净可用的块串起来,将来从buffer cache找可用块的时候就从LRU链中找。LRUW是将脏块链起来,将来DBWR将脏块写入磁盘时就访问LRUW链。

把块链起来的目的就是为了组织和管理buffer块。

Buffer cache中还有一种叫做检查点队列链(checkpoint chint)。检查点队列链和LRUW一样也是挂的脏块。

oracle按照被访问的频率从低到高把脏块挂在LRUW上。

Oracle按照第一次脏的时间依次把脏块挂到检查点队列链上。

 

RBA:redo block address。Redo日志块的地址。对buffer进行修改会产生日志,日志有自己的地址,这个地址就是RBA。当buffer脏了以后,就在buffer里记下RBA,将来buffer需要恢复时就知道从哪里找日志。

每个buffer保存了有两个地址:LRBA和HRBA。LRBA是buffer第一次被脏的日志的地址。HRBA记录buffer最近一次脏的日志的地址。LRBA和HRBA中间的地址区域描述了buffer被脏的过程。

 

由此可见检查点队列上的脏buffer是按照其LRBA地址链接起来的。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值