MySQL中的两阶段提交详解(2PC)

 更新时间:2025年05月12日 11:10:39   作者:小红的布丁  
这篇文章主要介绍了MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

引言

在InnoDB存储引擎中,当启用二进制日志(Binlog)且执行事务提交时,会触发两阶段提交(2PC)过程,以确保数据的一致性和持久化安全。

该过程首先将数据更新写入redo log buffer和Binlog缓存,然后通过分阶段的日志写入和持久化操作,实现事务的准备与提交状态转变。

两阶段提交机制不仅协调了InnoDB的事务日志与Binlog之间的同步,还依赖于关键配置参数如sync_binlog和innodb_flush_log_at_trx_commit,这些参数分别控制Binlog和redo log的写入与持久化策略。

本文将围绕两阶段提交的具体流程及相关配置,深入分析其在保证事务原子性和持久性中的核心作用。

两阶段提交过程

当在 InnoDB 中执行事务,并且启用了 Binlog 时,提交事务时会触发两阶段提交过程

  • 当有数据需要更新的时候,InnoDB 引擎就会先把记录写到redo log buffer以及binlog cache(线程独有的),并更新内存(change buffer),这个时候更新就算完成了。
  • 如果是唯一索引更新操作会写入到redo log buffer,普通索引的更新操作会先写入到change buffer,在合适的时机merge到redo log。
  • 事务提交时写入 redo log 并变成 prepare 状态。(一阶段)
  • 再把 binlog cache 写到 binlog 文件中,最后 redo log 变成 commit 状态。(二阶段)

sync_binlog配置

sync_binlog 用于控制commit时binlog的持久化,write表示将binlog cache中的日志,写入到文件系统的 page cache,fsync将表示数据持久化到磁盘。

  • sync_binlog=0 的时候,表示每次提交事务都只 write,不 fsync。(5.7及以前默认值)
  • sync_binlog=1 的时候,表示每次提交事务都会执行 fsync。(8.0及以后默认值)
  • sync_binlog=N(N>1)的时候,表示每次提交事务都 write,但累积 N 个事务后才 fsync。

innodb_flush_log_at_trx_commit配置

innodb_flush_log_at_trx_commit 用于控制commit时redo log的持久化。

  • innodb_flush_log_at_trx_commit=0 的时候,表示每次事务提交时都只是把 redo log 留在 redo log buffer 中。
  • innodb_flush_log_at_trx_commit =1 的时候,表示每次事务提交时都将 redo log 直接持久化到磁盘。(默认值)
  • innodb_flush_log_at_trx_commit=2 的时候,表示每次事务提交时都只是把 redo log 写到 page cache。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL错误代码:1052 Column 'xxx' in field list is ambiguous的原因和解决

    MySQL错误代码:1052 Column 'xxx' in field list is

    今天在工作中写sql语句时遇到了个sql错误,为记录并不再重复出错,下面这篇文章主要给大家介绍了关于MySQL错误代码:1052 Column 'xxx' in field list is ambiguous的原因和解决方法,需要的朋友可以参考下
    2023-04-04
  • mysql查看死锁与去除死锁示例详解

    mysql查看死锁与去除死锁示例详解

    这篇文章主要给大家介绍了关于mysql查看死锁与去除死锁的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • linux环境下安装mysql数据库的详细教程

    linux环境下安装mysql数据库的详细教程

    这篇文章主要介绍了linux环境下安装mysql数据库的详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • 与MSSQL对比学习MYSQL的心得(八)--插入 更新 删除

    与MSSQL对比学习MYSQL的心得(八)--插入 更新 删除

    这一篇《与MSSQL对比学习MYSQL的心得(八)》将会讲解MYSQL的插入、更新和删除语句
    2014-08-08
  • MySQL组合索引(多列索引)使用与优化案例详解

    MySQL组合索引(多列索引)使用与优化案例详解

    这篇文章主要介绍了MySQL组合索引(多列索引)使用与优化,主要包括多列索引,测试案例及过程以及多列索引的使用顺序,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • MySQL基本操作语句小结

    MySQL基本操作语句小结

    这篇文章主要介绍了MySQL的基本操作语句,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-07-07
  • mysql 5.7.13 解压缩版(免安装)安装配置教程

    mysql 5.7.13 解压缩版(免安装)安装配置教程

    这篇文章主要介绍了MySQL 5.7.13 for Windows解压缩版(免安装)安装配置教程,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • 详解MySQL如何实现数据批量更新

    详解MySQL如何实现数据批量更新

    最近需要批量更新大量数据,习惯了写sql,所以还是用sql来实现,下面这篇文章主要给大家总结介绍了关于MySQL批量更新的方式,需要的朋友可以参考下
    2023-10-10
  • 使用Mycat-eye管理Mycat数据库服务的操作

    使用Mycat-eye管理Mycat数据库服务的操作

    MyCat是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,本文给大家介绍了使用Mycat-eye管理Mycat数据库服务的操作,需要的朋友可以参考下
    2024-04-04
  • mysql中IFNULL,IF,CASE的区别介绍

    mysql中IFNULL,IF,CASE的区别介绍

    本文将详细介绍mysql中IFNULL,IF,CASE的区别,需要了解的朋友可以参考下
    2012-11-11

最新评论