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 是逻辑日志。
相关推荐
闪电悠米1 分钟前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
suoyue_zhan6 分钟前
SQL经典案例之数据库的CTE递归循环使用
数据库·sql
Sammyyyyy8 分钟前
2026 Mac 本地大模型部署深度解析与混合架构指南
数据库·人工智能·macos·ai·架构·servbay
zhangjw3412 分钟前
MySQL数据库零基础入门,数据库原理、SQL详解、库表操作、字段约束、基础查询全覆盖
数据库·sql·mysql
IT策士13 分钟前
Redis 从入门到精通:数据结构Set 与 Sorted
数据结构·数据库·redis
2401_8734794013 分钟前
如何用IP离线库检测DNS隧道和C2通信?企业DNS安全防护指南
网络·数据库·tcp/ip·安全·ip
填满你的记忆25 分钟前
10万QPS下,Redis缓存如何避免雪崩?
数据库·redis·缓存
神仙别闹28 分钟前
基于 PHP + MySQL 图书库存管理系统
android·mysql·php
IT界的老黄牛38 分钟前
MongoDB 主从切换排查实战:从 docker ps 到 jq,一套 SOP 定位死因
数据库·mongodb·docker
睡不醒男孩03082339 分钟前
第四篇:数据库国产化与信创替代的守护者:基于CLup的异构数据库一站式运维平台构建
运维·数据库·金融·clup·中启乘数