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 是逻辑日志。