当前位置: 首页 > web >正文

详解Mysql redo log与binlog的两阶段提交(2PC)

        在启用二进制日志(binlog)的情况下,MySQL通过两阶段提交(2PC)机制确保redo log与binlog的一致性,避免因崩溃导致数据不一致。

1. 两阶段提交(2PC)的核心目标

  • 原子性:确保事务在redo log和binlog中要么全部提交,要么全部回滚

  • 一致性:主库与从库的数据一致(依赖binlog的可靠性)。

  • 持久性:崩溃恢复后,已提交事务的数据不丢失。

2. 两阶段提交的详细流程

阶段1:Prepare(准备阶段)

  • InnoDB Prepare

    • 将事务的修改写入redo log,并标记为PREPARE状态。

    • 调用fsync将redo log刷盘(由innodb_flush_log_at_trx_commit=1控制)。

    • 此时事务尚未提交,但已保证redo log的持久性。

阶段2:Commit(提交阶段)

  • Write Binlog

    • 将事务的SQL语句按事件格式写入binlog

    • 调用fsync将binlog刷盘(由sync_binlog=1控制)。

  • InnoDB Commit

    • 将事务的COMMIT标记写入redo log,并再次刷盘。

    • 释放行锁,清理undo log(若不再被其他事务依赖)。

3. 崩溃恢复机制

        若在提交过程中发生崩溃,MySQL重启后按以下逻辑恢复:

  • 扫描redo log

    • 查找所有处于PREPARE状态的事务(未提交的事务)。

  • 检查binlog

    • 如果binlog中存在对应事务的完整记录(XID匹配),说明事务已成功写入binlog,提交该事务

    • 如果binlog中无对应事务记录,说明事务未完成binlog写入,回滚该事务

4. 关键参数与配置

  • sync_binlog

    • =0:依赖操作系统刷盘,性能高但可能丢失事务。

    • =1:每次提交刷盘,保证binlog不丢失(推荐主从复制场景)。

    • =N:每N次提交刷盘,平衡性能与可靠性。

  • innodb_flush_log_at_trx_commit

    • =1:每次提交刷redo log,保证持久性(默认)。

    • =0:每秒刷盘,可能丢失1秒数据。

    • =2:写入OS缓存,不立即刷盘。

  • binlog_order_commits

    • 控制是否按binlog写入顺序提交事务(默认开启,保证主从一致性)。

5. 示例:事务提交与崩溃恢复场景

场景1:InnoDB Prepare后,写binlog前崩溃
  • 现象:redo log有PREPARE记录,binlog无事务记录。

  • 恢复:回滚事务(因binlog未写入,主从不一致风险)。

场景2:binlog写入后,InnoDB Commit前崩溃
  • 现象:redo log有PREPARE记录,binlog有完整事务。

  • 恢复:提交事务(重做COMMIT标记到redo log)。

6. 性能优化策略

  • 组提交(Group Commit)

    • 合并多个事务的redo log和binlog刷盘操作,减少I/O次数。

    • binlog组提交:通过binlog_group_commit_sync_delay参数延迟刷盘,批量处理。

  • 调整刷盘参数

    • 非严格一致性场景可设置sync_binlog=0innodb_flush_log_at_trx_commit=2

  • 并行复制

    • 从库使用多线程应用binlog事件,提升主从同步速度。

7. 与XA事务的关系

  • XA协议:两阶段提交是XA协议在MySQL中的具体实现,用于协调多个资源管理器(如InnoDB与binlog)。

  • 分布式事务:若事务涉及多个存储引擎或外部系统,MySQL通过XA协议保证全局一致性。

8. 总结

        通过两阶段提交,MySQL确保了redo log(存储引擎层)与binlog(Server层)的强一致性,这是主从复制和数据恢复的核心基础。参数配置需权衡性能与可靠性,而崩溃恢复机制通过比对两种日志的状态,最终决定事务的提交或回滚,保障了数据库的ACID特性。

http://www.xdnf.cn/news/8826.html

相关文章:

  • 上海医日健集团社区 + 写字楼全域覆盖便民服务网
  • 如何在Windows右键菜单中添加“在此处以管理员身份打开Powershell窗口”的选项(含图标设置)
  • 论文阅读:arxiv 2024 SmoothLLM: Defending LLMs Against Jailbreaking Attacks
  • NNG和DDS
  • Ubuntu 22.04 高效Python依赖管理指南
  • 小程序使用web-view 修改顶部标题 安全认证文件部署在nginx
  • 疫情社区管理登记系统
  • 基于点标注的弱监督目标检测方法研究
  • springboot中拦截器配置使用
  • NeuralRecon技术详解:从单目视频中实现三维重建
  • 「OC」源码学习——KVO底层原理探究
  • 批量获取电商商品数据的解决方案|API接口自动化商品采集|item_get 接口详解
  • Vue.js教学第十五章:深入解析Webpack与Vue项目实战
  • 消息队列的使用
  • ClickHouse讲解
  • Qwen2.5 VL 自定义模型的回复数量
  • 基于文本挖掘与情感分析的B站《唐探1900》弹幕研究
  • Qt for Android 安卓低功耗蓝牙(BLE)开发环境搭建
  • 打卡day36
  • HUAWEI交换机配置镜像口验证(eNSP)
  • --legacy-peer-deps 是什么意思
  • 【不背八股】1.if __name__ == “__main__“ 有什么作用?
  • 【redis】redis和hiredis的基本使用
  • RabbitMQ 可靠性保障:消息确认与持久化机制(一)
  • day01
  • 算法打卡第六天
  • C++23 对部分特性的 constexpr 支持
  • 历年华南理工大学保研上机真题
  • 阿里千问系列:Qwen3技术报告解读(下)
  • 美团2025年校招笔试真题手撕教程(二)