深入详细解释Oracle 全量 CHECKPOINT 与增量 CHECKPOINT

两种检查点对业务用户完全透明。增量 CHECKPOINT本质是把全量检查点的脏块写入任务拆分、分时段批量落盘,能大幅降低数据库 I/O 压力与性能影响。

  1. 全量 CHECKPOINT
    全量检查点指 DBWR 进程将脏缓冲区内指定时间点前所有脏块一次性写入数据文件,以执行时刻t1为例,分为两步:
    DBWR 批量将t1之前产生的全部脏块落盘。脏块量大时会产生海量 I/O,若 DBWR 进程数不足,写入效率会明显下降。
    确认所有脏块写入完成后,CKPT 进程同步更新控制文件与数据文件头。
    该模式一次性集中刷写脏块,I/O 开销极高,不仅加重 DBWR 负载,还可能拖累线上业务,生产环境不建议频繁触发。
  2. 增量 CHECKPOINT
    Oracle 8 版本起引入增量检查点,核心是让 DBWR 持续消费 CKPTQ 队列中的脏块,平稳分摊磁盘 I/O。该特性由隐含参数_disable_incremental_checkpoints控制,默认启用。
    执行流程分为三步:
    脏块首次被修改时,对应重做日志的位置记为LRBA;所有脏块按 LRBA 排序形成 CKPTQ 队列。DBWR 遍历队列,按规则逐批刷写脏块,并同步递增内存中的检查点号(SCN)。
    脏块落盘成功后,DBWR 将其从 CKPTQ 队列中移除。
    CKPT 进程每 3 秒更新控制文件,记录增量检查点的 RBA 进度。
  3. 全量与增量 CHECKPOINT 核心区别
    脏块刷写方式
    全量 CHECKPOINT:一次性刷完某时间点前全部脏块,大库易引发性能抖动。
    增量 CHECKPOINT:按脏块生成顺序分批次持续刷写,流量平缓、负载可控。
    更新对象
    全量 CHECKPOINT:更新内存 SCN、数据文件头、控制文件。
    增量 CHECKPOINT:仅更新内存 SCN、控制文件内的检查点进度记录,不修改数据文件头(可通过 DUMP 控制文件查看进度)。
    触发条件
    全量 CHECKPOINT:多由手动命令主动触发。
    增量 CHECKPOINT:自动触发,受在线重做日志大小、FAST_START_MTTR_TARGET等参数管控。
相关推荐
数据库小学妹9 小时前
异构数据库同步实战:如何打通Oracle/MySQL/SQL Server的数据孤岛
数据库·mysql·oracle
数据库知识分享者小北10 小时前
安全可靠数据库选型之阿里云 PolarDB MySQL 版V2.0
数据库·mysql·阿里云·国产数据库·polardb·安全可靠数据库·polardb-m
一只fish10 小时前
Oracle官方文档翻译《Database Concepts 26ai》第16章-数据库实例
数据库·oracle
艾莉丝努力练剑10 小时前
【Linux:文件】库的制作与原理进阶
linux·运维·服务器·网络·数据库·c++·人工智能
深念Y10 小时前
DeepSeek/MiMo 推理链缓存代理:从内存到 SQLite 的两级缓存架构实战
数据库·缓存·架构·sqlite·内存·优化·分层
一点事11 小时前
oracle:手动同步数据库
数据库·oracle
努力攻坚操作系统11 小时前
ClickHouse详细教程
大数据·数据库·clickhouse
admin and root11 小时前
Blade站点的渗透测试到MySQL数据库权限接管
数据库·mysql·web安全·渗透测试·移动安全·培训·src赏金
Elastic 中国社区官方博客11 小时前
Elasticsearch:跨数据库与业务系统进行搜索
大数据·数据库·人工智能·elasticsearch·搜索引擎·全文检索