MySQL 三大日志(redo log、undo log、binlog)的区别和作用

MySQL 的三大日志是保证数据安全、事务一致性、主从复制的核心,三者缺一不可,也是理解 InnoDB 的关键。

✔ 一、redo log 重做日志(InnoDB 独有,事务持久性的保证)

  • 核心作用:保证事务的 持久性(ACID-D),解决「数据库崩溃后数据丢失」的问题。
  • 工作原理:InnoDB 是内存数据库,数据修改先写入内存的 buffer pool,再异步刷盘到磁盘。为了防止内存数据丢失,每次执行写操作时,都会先把修改记录写入 redo log,如果数据库崩溃,重启后会通过 redo log 恢复数据,保证数据不丢失。
  • 特点:物理日志(记录「哪个页修改了什么内容」)、循环写入(固定大小,写满覆盖)、事务提交时刷盘。

✔ 二、undo log 回滚日志(InnoDB 独有,事务原子性的保证)

  • 核心作用:保证事务的 原子性(ACID-A),实现「事务回滚」和「MVCC 多版本并发控制」。
  • 工作原理:执行写操作时,InnoDB 会先把「修改前的数据」写入 undo log,当事务执行失败需要回滚时,通过 undo log 恢复到修改前的状态;同时,undo log 也存储了数据的历史版本,供 MVCC 读取。
  • 特点:逻辑日志(记录「执行了什么反向操作」)、可回滚、支持多版本。

✔ 三、binlog 归档日志(MySQL 服务器层日志,所有引擎都支持)

  • 核心作用:实现 主从复制 和 数据备份 / 恢复,是 MySQL 分布式架构的核心。
  • 工作原理:记录所有的DDL 和 DML 语句(建表、增删改),以二进制形式存储,主库的 binlog 会同步到从库,从库执行 binlog 中的语句,实现主从数据一致。
  • 特点:逻辑日志、追加写入(写满新建文件,不覆盖)、有三种格式(STATEMENT/ROW/MIXED),生产推荐 ROW 格式。

✔ 三者核心区别(面试必答,满分答案)

  • 归属不同:redo/undo 是InnoDB 引擎层日志,binlog 是MySQL 服务器层日志; 作用不同:redo
  • 保证持久化,undo 保证原子性,binlog 保证主从同步; 写入方式不同:redo 循环写,undo/binlog 追加写;
  • 内容不同:redo 是物理日志,undo/binlog 是逻辑日志。
相关推荐
jiayou642 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫4 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8784 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H4 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql