MySQL技巧(九): Binlog 完整格式解析(ROW 模式,默认)

MySQL 5.7 默认 binlog 格式是 ROW(行模式) ,这是生产环境最常用、最稳定的格式。我给你一份可直接落地使用的解析指南,包含格式结构、解析命令、字段含义、实战案例。


一、MySQL 5.7 Binlog 核心特性

  1. 默认格式ROW(行模式)
  2. 记录内容 :不存 SQL,只存行数据变更的前后镜像
  3. 主从复制:绝对一致,无函数 / 存储过程偏差
  4. 支持:数据恢复、闪回、CDC 同步(Canal/Debezium)
  5. binlog 文件 :二进制文件,必须用 mysqlbinlog 解析

二、3 种格式在 5.7 中的表现

表格

格式 说明 5.7 是否推荐
ROW(默认) 记录行变更 ✅ 强烈推荐
STATEMENT 记录原始 SQL ❌ 不推荐(主从不一致)
MIXED 自动切换 ⚠️ 一般不使用

查看当前格式:

sql

复制代码
show variables like 'binlog_format';

三、ROW 模式 Binlog 结构(最重要)

一个完整的 binlog 事件包含:

  1. 事件头:时间、位置、语句类型
  2. 表映射:库名、表名、字段结构
  3. 行数据
    • 前镜像(before):变更前的数据(UPDATE/DELETE)
    • 后镜像(after):变更后的数据(INSERT/UPDATE)

四、mysqlbinlog 解析命令(5.7 专用)

1. 基础解析(能看懂行数据)

bash

运行

复制代码
mysqlbinlog -v --base64-output=DECODE-ROWS mysql-bin.000001

2. 详细解析(最常用)

bash

运行

复制代码
mysqlbinlog -vv --base64-output=DECODE-ROWS mysql-bin.000001
  • -v:简单解析行
  • -vv:显示字段名 + 类型 + 值(生产必备)

3. 按时间 / 位置解析

bash

运行

复制代码
# 按位置
mysqlbinlog --start-position=107 --stop-position=1000 -vv mysql-bin.000001

# 按时间
mysqlbinlog --start-datetime="2026-03-28 10:00:00" --stop-datetime="2026-03-28 11:00:00" mysql-bin.000001

五、ROW 格式解析实战(一看就懂)

示例 SQL

sql

复制代码
update user set age=26 where id=1;

解析后关键内容(精简版)

plaintext

复制代码
### UPDATE `test`.`user`
### WHERE
###   @1=1        (id, INT)
###   @2='张三'   (name, VARCHAR)
###   @3=25       (age, INT)
### SET
###   @1=1
###   @2='张三'
###   @3=26

字段含义

  • @1:第 1 列
  • @2:第 2 列
  • WHERE前镜像(原数据)
  • SET后镜像(新数据)

六、三种操作的 Binlog 表现

1. INSERT(只有后镜像)

plaintext

复制代码
### INSERT INTO `test`.`user`
### SET
###   @1=2
###   @2='李四'
###   @3=20

2. UPDATE(前 + 后镜像)

plaintext

复制代码
### UPDATE
### WHERE(原数据)
### SET(新数据)

3. DELETE(只有前镜像)

plaintext

复制代码
### DELETE FROM `test`.`user`
### WHERE
###   @1=1
###   @2='张三'
###   @3=26

七、MySQL 5.7 Binlog 关键配置(my.cnf)

ini

复制代码
server-id = 1
log_bin = mysql-bin
binlog_format = ROW        # 5.7 默认
expire_logs_days = 7      # 自动清理
binlog_row_image = full   # 默认:记录全部字段(推荐)
  • binlog_row_image=full:记录所有列(恢复最安全)
  • minimal:只记录修改列(省空间,但恢复麻烦)

八、常见问题

1. 解析出来是乱码?

必须加:

plaintext

复制代码
--base64-output=DECODE-ROWS -vv

2. 看不到字段名?

-vv 而不是 -v

3. 批量更新日志很大?

ROW 模式会记录每一行,正常现象。


总结(最核心)

  1. MySQL 5.7 默认 binlog = ROW 行模式
  2. 记录:行数据前后镜像
  3. 解析命令mysqlbinlog -vv --base64-output=DECODE-ROWS
  4. 结构:事件头 → 表信息 → 前镜像 (WHERE) → 后镜像 (SET)
  5. 用途:主从复制、数据恢复、CDC 同步
相关推荐
渣渣盟1 小时前
Mysql入门到精通全集(SQL99)包含关系运算,软考数据库工程师复习首选
数据库·mysql·oracle
2301_808414382 小时前
MySQL中的函数
数据库·mysql
Mahir082 小时前
MySQL 数据一致性的基石:三大日志( redo log/undo log/binlog)与两阶段提交(Prepare 阶段和Commit 阶段)深度解密
数据库·后端·mysql·面试
jiayong234 小时前
MySQL 8.0 Root 用户远程登录配置完整指南
数据库·mysql
@小柯555m5 小时前
MySql(高级查询--查找GPA最高值)
数据库·sql·mysql
轻刀快马5 小时前
穿透 MySQL 索引专栏 (五):【架构哲学】性能调优的终局之战:深分页灾难与千万级大表的索引设计原则
数据库·mysql·架构
whn19775 小时前
centos10.1上安装mysql 9.6
数据库·mysql
oldking呐呐5 小时前
MySQL从建库到删库跑路 -- 5.数据类型
mysql
黄俊懿6 小时前
复合索引设计指南:最左前缀 & 字段排座次
数据库·sql·mysql·adb·性能优化·dba·db
Fan_-_6 小时前
MySQL / PostgreSQL DDL 审核自动化:从人工 review 到 CI 拦截
mysql·postgresql·自动化