深入理解Oracle Checkpoint

一、Checkpoint(检查点)核心理解

把检查点类比成 Word 的保存,分为手动检查点、自动检查点两类。

核心流程:

CKPT(检查点进程)定期通知 DBWR(数据库写进程),将内存缓冲区(Buffer Cache)里被修改过的脏块,持久化写入磁盘数据文件。

  1. 核心作用:缩小内存脏块规模,保证内存与磁盘数据一致性;
  2. 最终目的:数据库异常宕机后,大幅缩短崩溃恢复(Crash Recovery)时长。
    原理:已写入磁盘、后续未再修改的脏块,重启恢复时可直接跳过,无需重做日志回放。
    检查点级别(Oracle 10g 及以上)
    共 4 个层级,粒度由大到小:
    数据库级 → 表空间级 → 数据文件级 → 对象级(Object)
    二、触发 DBWR 写脏块的常见场景
    满足任一条件,都会触发 DBWR 刷写脏块:
  3. 执行 Checkpoint 检查点操作
  4. 到达预设刷写时间阈值
  5. Buffer Cache 内脏块数量达到上限阈值
  6. 在线重做日志(Redo Log)发生切换
    补充:若脏块写入压力大、单 DBWR 效率不足,可启用多 DBWR 进程并行刷写,提升性能。
    运维提示:不同 Oracle 版本,脏块阈值、DBWR 调度算法存在差异,日常运维无需深究底层算法细节(Oracle 为闭源商业软件)。
    三、Redo 日志中记录 DBWR 刷块信息(Oracle 9i+)
    从 Oracle 9i 开始,在线重做日志(Online Redo Log)会记录 DBWR 写脏块行为,对应标识为 OP:23.1。
    该日志记录可让崩溃恢复进程快速识别 "已落盘且未再修改的数据块",直接跳过恢复逻辑,进一步提速。
    四、实操演示(Oracle 10g 环境日志转储)
  7. 查看数据库版本
    select * from v$version where rownum<2;

输出:Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - Prod

  1. 转储指定重做日志(筛选层 23、操作码 1,即 DBWR 刷块记录)

alter system dump logfile '/archlog/ora10205/1_64_788264706.dbf' layer 23 opcode 1;

  1. 操作系统层统计 & 查看跟踪文件
  2. 统计本次转储中Block Written(数据块已写入)总条数:
    bash

cat ora10205_ora_13871.trc|grep "Block Written"|wc -l

结果:4644 条,代表本次日志里共记录4644个被DBWR刷入磁盘的数据块

  1. 查看跟踪文件详情:
    cat ora10205_ora_13871.trc

关键字段解读(日志片段)

Block Written - afn: 4 rdba: 0x01002408 ... scn: 0x0000.000a1ecd

• Block Written:标识这是 DBWR 写入数据块的日志记录

• afn:文件编号

• rdba:数据块地址

• scn:系统改变号,标记数据块落盘时的版本

相关推荐
Lao A(zhou liang)的菜园11 小时前
Oracle 增量检查点(Incremental Checkpoint)I/O 优化方案
数据库·oracle
这个DBA有点耶12 小时前
SQL中的窗口函数进阶:滑动窗口与帧子句详解
数据库·sql·程序人生·mysql·oracle·学习方法·改行学it
tongyiixiaohuang12 小时前
跨平台数据库集成:SQLServer到MySQL的最佳实践
数据库·mysql·sqlserver
Undergoer_TW12 小时前
Colmap 进军嵌入式:SQLite 数据库从崩溃退出到自动治愈
jvm·数据库·sqlite
徐sir(徐慧阳)12 小时前
记一次麒麟 oracle 12c RAC安装迁移全过程
数据库·oracle
Mr. zhihao12 小时前
Redis 脑裂深度解析:Sentinel 与 Cluster 机制、流程及对比
数据库·redis·sentinel
努力攻坚操作系统12 小时前
MySQL 原理解析
数据库·mysql
数据库小学妹12 小时前
MySQL 字符集深度解析:utf8 vs utf8mb4 的底层差异与索引失效根因
数据库·经验分享·mysql
Daydream.V12 小时前
深入拆解 MySQL 锁机制:全局锁、表级锁、行级锁实战全解析
数据库·mysql·oracle·