iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么理解MySQL事务两段式提交
  • 154
分享到

怎么理解MySQL事务两段式提交

2024-04-02 19:04:59 154人浏览 安东尼
摘要

本篇内容主要讲解“怎么理解Mysql事务两段式提交”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解mysql事务两段式提交”吧!⒈两段式提交的目的:解决参

本篇内容主要讲解“怎么理解Mysql事务两段式提交”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解mysql事务两段式提交”吧!

⒈两段式提交的目的:解决参与者(redo log & binlog)的一致性

⒉两段式提交的原理:实际是防止参与方(资源管理者)部分提交(在binlog 与 redo log中,如果提交前redo log准备好,而binlog没准备好,直接提交,则binlog可能写失败;如果binlog准备,redo log没准备好,就会导致提交丢失)

⒊两段式提交的两个阶段:

第一阶段:为prepare阶段,TM(事务管理器)向RM(资源管理器)发出prepare指令,RM进行操作,然后返回成功与否的信息给TM;

第二阶段:为事务提交或者回滚阶段,如果TM收到所有RM的成功消息,则TM向RM发出提交指令;不然则发出回滚指令

⒋Binlog/Redo XA在Mysql版本的演变:

⑴5.5版本:

①第一阶段(innodb prepare)

持有prepare_commit_mutex

将undo状态改为prepare状态

将redo write/fsync回磁盘

binlog不做任何操作

②第二阶段(commit)

write/sync_binlog

innodb_commit(写入COMMIT标志后,释放prepare_commit_mutex互斥量)

这里有一个并发的缺陷就是prepare_commit_mutex这个互斥量,贯穿提交两阶段

⑵5.6版本:

①第一阶段(innodb prepare)

持有prepare_commit_mutex

将undo状态改为prepare状态

将redo write/fsync回磁盘

binlog不做任何操作

释放prepare_commit_mutex

②第二阶段(commit)

分为三个队列,分为三个小阶段(每一个阶段是一个队列,进入每个队列都有一个互斥量保护,有leader事物领导操作)

flush阶段:leader将一组事物的binlog 写入iocache

sync阶段:将binlog sync磁盘

commit阶段:根据参数binlog_order_commits的设定,进行提交

分为三阶段的优势是:拆分了之前的mutex,增加了并发性

但是redo log仍然是不能组提交

⑶5.7版本:

①第一阶段(innodb prepare)

持有prepare_commit_mutex

将undo状态改为prepare状态

将lsn记录到thd数据结构的lsn

binlog不做任何操作(这里如果是开启了GTID,就获取lock_interval的起始逻辑时钟,用于MTS的重放)

释放prepare_commit_mutex

②第二阶段(提交阶段)

分为三个队列,分为三个小阶段(每一个阶段是一个队列,进入每个队列都有一个互斥量保护,由leader事物线程领导操作)

⑴flush stage阶段:

leader事物线程搜集flush队列,找出最大的LSN,然后将redo log write/flush磁盘到这个最大的LSN

write binlog,将binlog写入io缓存

⑵sync阶段:

将binlog刷入磁盘

⑶commit阶段:

根据参数binlog_order_commits的设定,进行提交

优势:将历史redo在prepare阶段的write/sync改到了flush state,这样就能进行redo的组提交

⒌Binlog/Redo XA在参数的调整:

flush阶段:

binlog_max_flush_queue_time:5.7.9之前的版本可用,flush队列等待的时间

sync阶段:

binlog_group_commit_sync_delay:在进入sync阶段所等待的时间

binlog_group_commit_sync_no_delay_count:binlog_group_commit_sync_delay毫秒直到收集到binlog_group_commit_sync_no_delay_count个事务时,进行一次组提交;

commit阶段:

binlog_order_commits:控制binlog是否按照顺序提交

到此,相信大家对“怎么理解MySQL事务两段式提交”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么理解MySQL事务两段式提交

本文链接: https://www.lsjlt.com/news/62379.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么理解MySQL事务两段式提交
    本篇内容主要讲解“怎么理解MySQL事务两段式提交”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解MySQL事务两段式提交”吧!⒈两段式提交的目的:解决参...
    99+
    2024-04-02
  • 分布式事务CAP两阶段提交及三阶段提交详解
    目录1关于分布式系统1.1介绍1.2优势和不足2分布式事务2.1CAP理论2.2CAP的组合情况2.3数据一致性模型2.4分布式事务应用场景2.4.1典型支付场景2.4.2 ...
    99+
    2024-04-02
  • Mycat分布式事务两阶段提交过程是怎样的
    本篇文章为大家展示了Mycat分布式事务两阶段提交过程是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 两阶段提交过程可以用以下图...
    99+
    2024-04-02
  • 如何理解mysql隐式提交事务transaction
    如何理解mysql隐式提交事务transaction,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。隐式提交事务概述  事务是一个完整...
    99+
    2024-04-02
  • 分布式数据库事务的两阶段提交介绍
    在分布式系统中,各个节点之间在物理上相互独立,通过网络进行沟通和协调。由于存在事务机制,可以保证每个独立节点上的数据操作可以满足ACID。但是,相互独立的节点之间无法准确的知道其他节点中的事务执行情况。所以...
    99+
    2024-04-02
  • MySQL的两阶段提交机制是什么
    本文小编为大家详细介绍“MySQL的两阶段提交机制是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL的两阶段提交机制是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2023-02-11
    mysql
  • MySQL事务提交的三个阶段是什么
    本篇内容介绍了“MySQL事务提交的三个阶段是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事务提交分...
    99+
    2024-04-02
  • MongoDB数据库两阶段提交实现事务的方法详解
    本文实例讲述了MongoDB数据库两阶段提交实现事务的方法。分享给大家供大家参考,具体如下: MongoDB数据库中操作单个文档总是原子性的,然而,涉及多个文档的操作,通常被作为一个“事务”,而不是原子性的...
    99+
    2024-04-02
  • 如何理解MySQL层事务提交流程
    如何理解MySQL层事务提交流程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。部分栈帧:prepare栈帧(gdb) bt #0&n...
    99+
    2024-04-02
  • mysql 5.5 lock tables与隐式事务提交commit
    结论:lock tables可以隐式提交其它会话的未提交事务 测试明细: ----session 1 mysql> start transaction; Query OK, 0 rows affec...
    99+
    2024-04-02
  • MySQL未提交事务造成的等待事件怎么解决
    本篇内容主要讲解“MySQL未提交事务造成的等待事件怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL未提交事务造成的等待事件怎么解决”吧! ...
    99+
    2024-04-02
  • 如何理解EF Core事务提交
    本篇内容主要讲解“如何理解EF Core事务提交”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解EF Core事务提交”吧!控制事务可以使用 DbCont...
    99+
    2024-04-02
  • MySQL事务处理:自动提交与手动提交的区别
    MySQL事务处理:自动提交与手动提交的区别 在MySQL数据库中,事务是一组SQL语句的集合,要么全部执行成功,要么全部执行失败,保证了数据的一致性和完整性。在MySQL中,事务可以...
    99+
    2024-04-02
  • mysql怎么查看事务是否自动提交
    要查看MySQL的事务是否自动提交,可以使用以下查询语句: SHOW VARIABLES LIKE 'autocommit...
    99+
    2024-04-02
  • 怎么理解sqlserver禁止management studio的自动提交事务
    这篇文章将为大家详细讲解有关怎么理解sqlserver禁止management studio的自动提交事务,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。自动...
    99+
    2024-04-02
  • MySQL中begin后事务为什么不提交
    这篇文章主要介绍“MySQL中begin后事务为什么不提交”,在日常操作中,相信很多人在MySQL中begin后事务为什么不提交问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • 怎么在MySQL中找出未提交的事务信息
    本篇文章给大家分享的是有关怎么在MySQL中找出未提交的事务信息,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。mysql> s...
    99+
    2024-04-02
  • 怎么理解MySQL事务
    这篇“怎么理解MySQL事务”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么理解MySQL事务”文章吧。事务指逻辑上的一组...
    99+
    2023-06-26
  • MySQL中Spring管理的事务开启后不提交引起的事故
    1. 前言 了解到一个事故,在MySQL数据库中,使用Spring管理的事务在开启以后没有在操作结束时提交或回滚,使得原有线程在后续执行数据库操作时可能继续使用原有事务,且不会提交,导致对数据库的修改...
    99+
    2023-09-03
    spring mysql java
  • mysql实现事务的提交与回滚的实例详解
    最近要对数据库的数据进行一个定时迁移,为了防止在执行过程sql语句因为某些原因报错而导致数据转移混乱,因此要对我们的脚本加以事务进行控制。 首先我们建一张tran_test表 CREATE TABLE ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作