首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何作为mysql代理执行分布式事务

如何作为mysql代理执行分布式事务
EN

Stack Overflow用户
提问于 2016-07-04 14:18:45
回答 0查看 201关注 0票数 0

我正在开发一个分布式数据库中间件,它打算充当MySQL的代理。当涉及到跨多个MySQL的事务时,我发现很难让多个MySQL作为一个整体提交或回滚。下面是案例:

假设我的数据库中间件代理了两个mysql实例,在应用程序端,当我想对这两个mysql实例执行"prepare-commit“操作时,首先我向中间件发送"prepare”请求,中间件将请求转发给这两个mysql实例,然后我通过中间件执行一些sql,最后,当我向中间件发送“提交”请求时,中间件会将请求转发给这两个mysql实例,下面是我感到困惑的地方:

如果发送到第一个mysql实例的commit请求执行成功,而发送到第二个实例的commit请求不知何故失败,据我所知,如果事务已经提交,则无法回滚,但这导致两个mysql实例处于不一致的状态。

我想知道如何处理这个问题,任何帮助都将不胜感激。

EN

回答

页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38177993

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档