文章详情页
MySQL数据库中间件如何实现分布式事务
浏览:241日期:2022-06-20 14:47:44
问题描述
假设我有两个MySQL数据库节点,在这两个节点前面有一个数据库中间件,应用通过数据库中间件来使用后面的两个MySQL节点, 结构如下图所示:

当应用通过中间件执行一个事务时,这个事务需要由中间件转发给两个MySQL节点,于是在中间件这一层,原本普通的事务现在升级成了跨越两个MySQL节点的分布式事务。对于应用程序来说,应用程序希望这个事务要么都被两个MySQL节点执行成功,要么都不成功。
当应用程序begin了事务,执行一系列SQL语句后,应用程序进行commit,此时数据库中间件会分别向两个MySQL节点发送commit命令,假设两个MySQL节点都接收到了commit命令,并成功提交,那么事务执行成功。如果其中一个节点commit成功,而另外一个节点由于一些原因无法执行commit(可能网络断开,或者MySQL数据库出现错误),又由于已经commit的事务无法rollback,所以此时两个MySQL节点就出现了数据不一致的情况。
我的问题是:目前是否有上述问题的解决方法或解决思路,先谢谢了
问题解答
回答1:xa
事务资源预分配
业务原子操作
相关文章:
1. css - 小程序canvas环形进度条2. mysql多表查询3. javascript - 调微信分享朋友接口,出现下面问题,求解答,4. 在别的电脑使用JDBC连接其他电脑上安装的mysql数据库5. 主从复制 - MySQL 主从延迟 300s 以上,求大神解答6. javascript - Object.create(null) 和 {} 区别是什么7. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?8. 微信扫码跳转页面是怎么实现的9. javascript - 关于iscroll的一段代码,希望有人解释10. 老师,CSS3里面,选择一个DIV,这个DIV是以什么为原点进行旋转的啊?
排行榜

网公网安备