深入详细解释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等参数管控。
相关推荐
冬奇Lab11 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence21 小时前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神1 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡2 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧2 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon2 天前
SQL学习指南——视图
数据库·sql
活宝小娜2 天前
mysql详细安装教程
数据库·mysql·adb
贤时间2 天前
codex 助力oracle ebs 开发
数据库·oracle