两种检查点对业务用户完全透明。增量 CHECKPOINT本质是把全量检查点的脏块写入任务拆分、分时段批量落盘,能大幅降低数据库 I/O 压力与性能影响。
- 全量 CHECKPOINT
全量检查点指 DBWR 进程将脏缓冲区内指定时间点前所有脏块一次性写入数据文件,以执行时刻t1为例,分为两步:
DBWR 批量将t1之前产生的全部脏块落盘。脏块量大时会产生海量 I/O,若 DBWR 进程数不足,写入效率会明显下降。
确认所有脏块写入完成后,CKPT 进程同步更新控制文件与数据文件头。
该模式一次性集中刷写脏块,I/O 开销极高,不仅加重 DBWR 负载,还可能拖累线上业务,生产环境不建议频繁触发。 - 增量 CHECKPOINT
Oracle 8 版本起引入增量检查点,核心是让 DBWR 持续消费 CKPTQ 队列中的脏块,平稳分摊磁盘 I/O。该特性由隐含参数_disable_incremental_checkpoints控制,默认启用。
执行流程分为三步:
脏块首次被修改时,对应重做日志的位置记为LRBA;所有脏块按 LRBA 排序形成 CKPTQ 队列。DBWR 遍历队列,按规则逐批刷写脏块,并同步递增内存中的检查点号(SCN)。
脏块落盘成功后,DBWR 将其从 CKPTQ 队列中移除。
CKPT 进程每 3 秒更新控制文件,记录增量检查点的 RBA 进度。 - 全量与增量 CHECKPOINT 核心区别
脏块刷写方式
全量 CHECKPOINT:一次性刷完某时间点前全部脏块,大库易引发性能抖动。
增量 CHECKPOINT:按脏块生成顺序分批次持续刷写,流量平缓、负载可控。
更新对象
全量 CHECKPOINT:更新内存 SCN、数据文件头、控制文件。
增量 CHECKPOINT:仅更新内存 SCN、控制文件内的检查点进度记录,不修改数据文件头(可通过 DUMP 控制文件查看进度)。
触发条件
全量 CHECKPOINT:多由手动命令主动触发。
增量 CHECKPOINT:自动触发,受在线重做日志大小、FAST_START_MTTR_TARGET等参数管控。