概述
文章目录
- 分布式事务
- MySQL数据库分布式事务
- 内部XA事务
分布式事务
MySQL数据库分布式事务
InnoDB存储引擎提供了对XA事务的支持,并通过XA事务来支持分布式事务的实现。分布式事务指的是允许多个独立的事务资源参与到一个全局的事务中。全局事务要求在其中的所有参与的事务要么都提交,要么都回滚,这对事务原有的ACID要求又有了提高。
在使用分布式事务时,InnoDB存储引擎事务隔离级别必须设置为 SERIALIZABLE。
XA事务由一个或多个资源管理器、一个事务管理器以及一个应用程序组成。
- 资源管理器:提供访问事务资源的方法。通常一个数据库就是一个资源管理器。
- 协调参与全局事务中的各个事务。需要和参与全局事务的所有资源管理器进行通信。
- 应用程序:定义事务的边界,指定全局事务中的操作。
在 Mysql 数据库的分布式事务中,资源管理器就是 Mysql 数据库,事务管理器为连接 Mysql 服务器的客户端。
分布式事务使用两段式提交的方式。在第一阶段,所有参与全局事务的结点都开始准备(PREPARE),告诉事务管理器他们准备好提交了。在第二阶段,事务管理器告诉资源管理器执行 ROLLBACK 还是 COMMIT。如果任何一个结点显示不能提交,则所有的结点都被告知需要回滚。
内部XA事务
上述的分布式事务是外部事务,即资源管理器是 Mysql 数据库本身。在 Mysql 数据库中还存在另一种分布式事务,其在存储引擎与插件之间,又或者在存储引擎与存储引擎之间,称之为内部XA事务。
最常见的内部XA事务存在于 binlog 与 InnoDB 存储引擎之间。由于复制的需要,因此目前绝大多数的数据库都开启了 binlog 功能。在事务提交时,先写二进制日志,再写 InnoDB 存储引擎的重做日志。上述两个操作必须是原子的。
最后
以上就是简单海燕为你收集整理的Mysql分布式事务分布式事务的全部内容,希望文章能够帮你解决Mysql分布式事务分布式事务所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复