news 2026/4/23 1:29:35

MySQL中的binlog日志

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL中的binlog日志

一、什么是binlog?

binlog(二进制日志)是MySQL用来记录所有数据变更操作的文件。

就像一个"监控录像",MySQL把每一个INSERT、UPDATE、DELETE操作都记录下来。

二、为什么需要binlog?

想象一个场景:你的电商系统突然宕机了,已经处理的订单数据丢失。这时候有了binlog就像有了"黑匣子",你可以用它来恢复丢失的数据。

2-1、binlog的主要用途有三个:

1. 数据恢复- 系统故障时,可以用binlog恢复到某个时间点的数据状态

2. 主从复制- 从库通过读主库的binlog来保持数据同步。这是构建高可用系统的基础

3. 审计追踪- 可以查看谁在什么时间修改了什么数据

2-2、binlog的三种格式

1、STATEMENT格式(记录SQL语句)

比如你执行:UPDATE users SET age = age + 1 WHERE id > 100 binlog就记录这条SQL语句原文

优点:记录量小,节省空间

缺点:某些函数(如NOW())可能导致从库数据不一致

2、ROW格式(记录行数据变化)

不记录SQL语句,而是记录"id=101的用户age字段从20变成21" 详细记录每一行数据变化前后的值

优点:最安全,不会有数据不一致的问题

缺点:记录量大,占用空间多

3、MIXED格式(混合模式)

MySQL智能选择:普通操作用STATEMENT格式,可能有问题的操作用ROW格式

三、如何启用binlog?

编辑MySQL配置文件my.cnf

[mysqld] server-id = 1 log-bin = /var/log/mysql/mysql-bin binlog-format = ROW expire-logs-days = 7

然后重启MySQL服务。

四、实际操作示例

查看binlog是否启用:

SHOW VARIABLES LIKE 'log_bin'; -- 结果:ON 表示已启用

查看当前binlog文件列表:

SHOW BINARY LOGS; -- 显示:mysql-bin.000001, mysql-bin.000002 等

查看binlog内容(以可读的方式):

mysqlbinlog /var/log/mysql/mysql-bin.000001

输出会显示类似这样的内容:

# at 154 #250107 10:30:45 server id 1 end_log_pos 235 Query thread_id=2 exec_time=0 error_code=0 SET TIMESTAMP=1704597045/*!*/; INSERT INTO users (id, name, age) VALUES (1, 'Alice', 25)

4-1、一个完整的场景理解

假设你有个电商系统:

10:00 - 用户购买商品,订单状态改为"已支付" 10:05 - 系统宕机了 10:10 - 系统恢复,但这5分钟的数据丢了 此时你可以: 1. 查看binlog中10:00-10:05的所有操作 2. 用mysqlbinlog工具恢复这部分数据 3. 系统恢复正常

五、三个日志的作用

  • undo log:用于事务回滚,记录数据修改前的旧值
  • redo log:用于崩溃恢复,记录数据修改后的新值
  • binlog:用于主从复制和数据恢复,记录所有数据变更

5-1、三种日志的层次归属

日志类型所属层次文件后缀负责模块
BinlogServer层.000001,.000002...MySQL Server
Undo Log存储引擎层(InnoDB)ibdata1,undo001InnoDB 引擎
Redo Log存储引擎层(InnoDB)ib_logfile0,ib_logfile1InnoDB 引擎

5-2、详细对比三种日志

1. Binlog(二进制日志)

归属:Server层(所有引擎共用)
作用:主从复制 + 数据恢复

特点:
• 逻辑日志:记录SQL语句或行变化(ROW格式记录变化前后的值)
• 追加写入:一直往后写,文件满了切下一个
• 所有引擎共享:不管用InnoDB还是MyISAM,都会记录

为什么 Binlog 在 Server 层?

设计目标:支持所有存储引擎的主从复制

2. Undo Log(回滚日志)

归属:存储引擎层(InnoDB特有)
作用:事务回滚 + MVCC多版本控制

特点:
• 物理日志:记录数据修改前的旧版本
• 循环使用:空间会被复用
• 实现MVCC:提供事务的隔离性(可重复读)

3. Redo Log(重做日志)

归属:存储引擎层(InnoDB特有)
作用:崩溃恢复 + 保证持久性
特点:
• 物理日志:记录数据页的物理变化
• 循环写入:固定大小文件循环写
• Write-Ahead Logging:先写日志,后写数据

为什么 Redo/Undo 在引擎层?

设计目标:事务实现是引擎自己的事

不同引擎的事务实现不同
• InnoDB:需要 Redo/Undo
• MyISAM:根本没有事务,不需要这些日志

只有 InnoDB 需要 Redo/Undo Log 吗?

是的!

  • MyISAM:没有事务,崩溃可能丢数据

  • Memory:数据在内存,重启就丢

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:33:21

格雷希尔:G15F-KFYK-FD39 定制款快速密封连接器,适配自动化产线,赋能电驱动通讯接口的自动化密封测试

某新能源设备商联系到我们,为其电驱动上的通讯接口采购一批快速密封连接器用于气密性测试,该生产线为自动化产线,对连接器的适配性、稳走性、耐用性均提出了极高要求。格雷希尔定制款 G15F-KFYK-FD39 自动化连接器格雷希尔定制款 G15F-KFYK-F…

作者头像 李华
网站建设 2026/4/18 14:45:07

2025年终总结 - 微分几何助力突破具身智能发展的瓶颈

今天是 2025 年 12 月 31 日,又到了一年一度回顾与思考的时刻。回望 2025 年,人工智能正在以前所未有的速度重塑人类社会结构,而具身智能(Embodied Intelligence)正逐渐成为这一轮技术浪潮中的核心焦点。所谓具身智能&…

作者头像 李华
网站建设 2026/4/17 17:14:55

Nordic方案——无线射频模组AS01-ML01SC

Nordic Semiconductor在无线性能和精密度方面拥有领先业界的表现,即使是对成本极为敏感的消费类产品,也能运用该公司的超低功耗 (ULP) 无线芯片。Nordic Semiconductor的芯片广泛用于无线PC外设、游戏控制器、体育和健身传感器、玩具、先进的多媒体控制器…

作者头像 李华
网站建设 2026/4/20 22:56:47

力扣96 不同的二叉搜索树 java实现

96.不同的二叉搜索树给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。示例 1:输入:n 3 输出:5示例 2:输入:n 1 输出…

作者头像 李华
网站建设 2026/4/21 0:24:29

全网最全专科生必用TOP8 AI论文平台测评

全网最全专科生必用TOP8 AI论文平台测评 2026年专科生论文写作工具测评:为何需要一份权威榜单? 随着AI技术在学术领域的广泛应用,越来越多的专科生开始借助AI工具提升论文写作效率。然而,面对市场上琳琅满目的论文平台&#xff0c…

作者头像 李华
网站建设 2026/4/23 12:49:50

当前Agent主流框架简介

LangChain干什么:把“外部 API 向量库 LLM”用链条(Chain)和记忆(Memory)串成可复用模板。适用:需要多步推理、调用外部工具(搜索、计算器、数据库)的问答或自动化流程。优点&…

作者头像 李华