Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL Redo Log落盘机制

MySQL Redo Log落盘机制深度解析

作者:·云扬·

本文主要介绍了MySQL Redo Log落盘机制深度解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MySQL InnoDB 引擎的事务持久性(ACID 中的 D)完全依赖于重做日志(Redo Log)。不同于二进制日志(Binlog)记录 SQL 逻辑,Redo Log 以物理格式记录数据页的修改,具备崩溃恢复能力。而 Redo Log 的落盘机制 —— 即内存缓冲区(Redo Log Buffer)数据刷写到物理磁盘的策略,直接决定了数据库的性能上限数据安全性底线

核心配置参数 innodb_flush_log_at_trx_commit 正是调控这一机制的关键,本文将从参数解析、实验验证、场景选型三个维度,带你彻底掌握 Redo Log 落盘的底层逻辑。

一、核心参数:innodb_flush_log_at_trx_commit 详解

1.1 参数作用

该参数控制事务提交时 Redo Log 的刷盘策略,取值仅支持 0、1、2 三种,默认值为 1(最安全模式)。

1.2 三种配置的落盘规则

参数值落盘逻辑依赖组件
0事务提交不触发刷盘,依赖 OS 每秒自动刷盘操作系统缓存(Page Cache)
1事务提交时立即写入磁盘文件,并调用fsync()强制刷入物理磁盘直接操作物理磁盘,不依赖 OS 缓存
2事务提交时写入磁盘文件(仅存入 OS 缓存),OS 每秒自动刷盘操作系统缓存 + 定期刷盘机制

注:

fsync()是操作系统调用,作用是强制将文件缓冲区数据写入物理存储介质,避免缓存丢失。

1.3 查看当前配置

show global variables like "innodb_flush_log_at_trx_commit";

二、实验验证:不同配置的性能差异

为量化三种配置的性能影响,我们设计了批量插入测试(10 万条数据),实验环境为单机 MySQL 8.0,InnoDB 存储引擎。

2.1 实验准备

# 选择数据库
use maria;
# 创建测试表
create table redo_t1(
  id int not null auto_increment,
  a varchar(20) default null,
  b int default null,
  c datetime not null default current_timestamp,
  primary key(id)
)engine=innodb charset=utf8mb4;
# 创建存储过程:插入 10 万行数据
delimiter ;;
create procedure insert_t1()
begin
  declare i int;
  set i=1;
  while(i<=100000)do
    insert into redo_t1(a,b) values (i,i);
    set i=i+1;
  end while;
end;;
delimiter ;

2.2 实验结果(单线程测试)

配置值执行耗时性能排序数据丢失风险
0约 11 秒最优高(最多丢失 1 秒数据)
1约 65 秒最差无(完全 ACID 兼容)
2约 17 秒中等低(仅 OS 崩溃时丢失缓存数据)

2.3 实验结论

三、配置选型:业务场景决定最优解

3.1 综合对比表

配置值核心特点适用场景禁忌场景
0性能最优,安全性最低非核心业务(日志存储、监控数据)、允许少量数据丢失金融支付、核心交易系统
1安全性最高,性能最差金融、电商支付、政务系统等核心业务非核心低优先级服务(资源浪费)
2性能与安全平衡普通业务系统、非核心交易(如订单历史)虚拟机 / 云服务器(OS 崩溃风险高)

3.2 关键注意事项

四、总结:没有最优配置,只有最适合的选择

Redo Log 的落盘机制本质是性能与安全性的权衡

理解 Redo Log 的落盘机制,不仅能帮助我们解决数据库性能瓶颈,更能在架构设计时做出符合业务特性的技术选型 —— 这正是 MySQL 底层原理学习的核心价值所在。

到此这篇关于MySQL Redo Log落盘机制深度解析的文章就介绍到这了,更多相关MySQL Redo Log落盘机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

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