深入理解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:系统改变号,标记数据块落盘时的版本

相关推荐
冬奇Lab9 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence20 小时前
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