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 是逻辑日志。
相关推荐
XDHCOM2 小时前
MySQL CASE WHEN语句应用实例:如何实现条件查询与数据转换?
数据库·mysql
Jul1en_2 小时前
【Redis】常用命令及定时器实现思想
数据库·redis·缓存
杰克尼2 小时前
redis(day02-短信登录)
数据库·redis·缓存
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB的分片管理(17)
数据库·学习·mongodb
木下~learning2 小时前
MySQL 从入门到精通:安装、终端操作、远程连接与 C 语言 API 全教程
c语言·数据库·mysql
不会写DN2 小时前
如何设计应用层 ACK 来补充 TCP 的不足?
开发语言·网络·数据库·网络协议·tcp/ip·golang
升职佳兴2 小时前
告别套娃式子查询:SQL WITH 语句(CTE)深度实战指南
数据库·sql
zzh0812 小时前
PG数据库日常应用
数据库·oracle
阿维的博客日记2 小时前
MySQL中type字段解析
数据库·mysql