Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL日志redo log、undo log、binlog

MySQL三大日志之redo log、undo log、binlog示例详解

作者:c-der

在MySQL数据库的运行机制中,Redo Log、Undo Log和Binlog起着至关重要的作用,它们各司其职,共同保障数据库的数据安全、事务一致性以及高效的复制与恢复功能,这篇文章主要介绍了MySQL三大日志之redo log、undo log、binlog的相关资料,需要的朋友可以参考下

前言

在 MySQL 数据库中,日志系统是保障数据一致性、支持事务和故障恢复的核心组件。其中,redo log(重做日志)、undo log(回滚日志)和 binlog(二进制日志)被称为"三大日志",它们分工协作,共同维护着数据库的可靠性和可用性。本文将深入解析这三种日志的工作原理、应用场景及它们之间的协同机制。

1. redo log(重做日志):保障数据持久性

1.1 什么是 redo log?

redo log 是 InnoDB 存储引擎特有的物理日志,用于记录数据页的物理修改操作。它的核心作用是保证事务的持久性(ACID 中的 D),防止 MySQL 意外崩溃后丢失已提交的数据。

1.2 工作原理:Write-Ahead Logging (WAL)

redo log 采用了预写日志机制,即当事务执行数据修改时:

  1. 先将修改操作记录到内存中的 redo log buffer
  2. 再异步或同步地将 redo log 写入磁盘
  3. 最后在合适的时机将内存中的数据页(Buffer Pool)刷写到磁盘

这种机制确保了即使数据还未写入磁盘,只要 redo log 已持久化,MySQL 重启后就能通过 redo log 恢复这些修改,从而保证已提交事务的数据不会丢失。

1.3 关键特性

1.4 刷盘策略配置

redo log 的刷盘策略由 innodb_flush_log_at_trx_commit 参数控制,有三种取值:

-- 查看当前配置
SHOW VARIABLES LIKE 'innodb_flush_log_at_trx_commit';

2. undo log(回滚日志):保障事务原子性

2.1 什么是 undo log?

undo log 是 InnoDB 存储引擎的逻辑日志,用于记录事务修改前的数据状态。它的核心作用是保障事务的原子性(ACID 中的 A),支持事务回滚操作,同时也是实现 MVCC(多版本并发控制)的基础。

2.2 工作原理

当事务执行修改操作时:

  1. InnoDB 会先记录数据修改前的状态到 undo log
  2. 如果事务执行失败或调用 ROLLBACK,InnoDB 会利用 undo log 还原数据到修改前的状态
  3. 在 MVCC 机制中,其他事务可以通过 undo log 访问数据的历史版本,实现"读不加锁"

例如,当执行 UPDATE t SET name = 'B' WHERE id = 1 时,undo log 会记录"将 id=1 的 name 改回 ‘A’"(假设原来的值是 ‘A’)。

2.3 关键特性

2.4 存储与刷盘

undo log 存储在 InnoDB 的 undo 表空间中,本质上是一种特殊的数据页。它的刷盘策略与普通数据页一致:

3. binlog(二进制日志):支持复制与恢复

3.1 什么是 binlog?

binlog 是 MySQL 服务器层的逻辑日志,记录了所有 DDL(数据定义语言)和 DML(数据操纵语言)操作。它不依赖于特定的存储引擎,所有引擎都可以使用。

3.2 主要作用

3.3 工作原理

当执行数据修改操作时:

  1. 操作会被记录到 binlog 缓存中
  2. 事务提交时,binlog 会被写入磁盘
  3. binlog 以事件形式记录,包含操作类型、数据变更、时间戳等信息

3.4 日志格式

binlog 有三种格式,通过 binlog_format 参数配置:

-- 查看当前格式
SHOW VARIABLES LIKE 'binlog_format';

3.5 刷盘策略

binlog 的刷盘策略由 sync_binlog 参数控制:

-- 查看当前配置
SHOW VARIABLES LIKE 'sync_binlog';

4. 三大日志的协同工作机制

在一个完整的事务处理过程中,三种日志会协同工作,确保数据的一致性和可靠性:

  1. 事务开始:InnoDB 为事务分配事务 ID
  2. 执行修改
    • 记录数据修改前的状态到 undo log
    • 修改内存中的数据页(Buffer Pool)
    • 记录数据页的修改到 redo log buffer
  3. 事务提交
    • 执行两阶段提交(2PC):
      a. 阶段一:将 redo log 标记为"prepare"状态并刷盘
      b. 阶段二:写入 binlog 并刷盘
      c. 阶段三:将 redo log 标记为"commit"状态并刷盘
    • 释放锁资源
  4. 后台操作
    • 定期将 Buffer Pool 中的数据页刷写到磁盘
    • 事务提交后,undo log 被标记为可回收,等待 purge 线程清理

这种协同机制确保了:

5. 三大日志的核心区别

特性redo logundo logbinlog
所属层级InnoDB 存储引擎层InnoDB 存储引擎层MySQL 服务器层
主要作用保证事务持久性(崩溃恢复)保证事务原子性(回滚)+ MVCC主从复制 + 时间点恢复
日志类型物理日志(数据页修改)逻辑日志(操作逆过程)逻辑日志(SQL 或行修改)
生命周期循环写(可覆盖)事务提交后可回收追加写(不覆盖)
刷盘时机事务执行中实时写入,提交时确保持久化随数据页异步刷盘事务提交时写入
存储引擎依赖仅 InnoDB 支持仅 InnoDB 支持所有引擎都支持

6. 总结

MySQL 的三大日志各有侧重又协同工作,共同构建了数据库的事务安全和可靠性体系:

理解这三种日志的工作原理和协同机制,对于数据库性能优化、故障排查和架构设计都具有重要意义。在实际应用中,应根据业务需求合理配置日志参数,在数据安全性和性能之间找到最佳平衡点。

到此这篇关于MySQL三大日志之redo log、undo log、binlog的文章就介绍到这了,更多相关MySQL日志redo log、undo log、binlog内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文