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 是逻辑日志。
相关推荐
zh1570232 小时前
JavaScript中WorkerThreads解决服务端计算瓶颈
jvm·数据库·python
代码AI弗森2 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
摇滚侠3 小时前
expdp 查看帮助
java·数据库·oracle
流年似水~3 小时前
MCP协议实战:从零搭建一个让Claude能“看见“数据库的工具服务
数据库·人工智能·程序人生·ai·ai编程
2401_871492853 小时前
Vue.js监听器watch利用回调函数处理级联下拉框数据联动
jvm·数据库·python
志栋智能4 小时前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
zhoutongsheng5 小时前
C#怎么实现Swagger文档 C#如何在ASP.NET Core中集成Swagger自动生成API文档【框架】
jvm·数据库·python
WinterKay5 小时前
【开源】我写了一个轻量级本地数据库浏览工具,支持 MySQL/Redis 只读查询
数据库·mysql·开源
zxrhhm6 小时前
Oracle 索引完整指南
数据库·oracle
程序猿乐锅7 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql