2016-07-04 119 views
0

我正在开发一个分布式数据库中间件,它打算作为MySQL的代理。当谈到跨多个MySQL的事务时,我发现很难让多个MySQL作为整体提交或回滚。这里是这样的情况:如何执行作为MySQL代理的分布式事务

说有2个mysql实例是由我的数据库中间件代理的,在应用程序端,当我想对两个mysql实例执行“prepare-commit”操作时,首先,我发送向中间件“准备”请求,中间件将请求转发给2个mysql实例,然后通过中间件执行一些sql,最后,当我向中间件发送“提交”请求时,中间件会将请求转发给2个mysql实例,这里是让我困惑的事情:

如果发送到第一个mysql实例的“提交”请求成功执行,而发送到第二个实例的“提交”请求以某种方式失败,如我所知,如果一个事务已经被提交,它不能被回滚,但是这个h因为导致2个mysql实例处于不一致的状态。

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

回答

0

一个承诺,一个失败,协调员应记录事务更改,并将成功返回给用户。一旦失败的实例恢复,从协调器检索日志并确保一致性。就像mysql作为协调者的binlog一样,你的中间件应该承担相同的责任。

MySQL外部XA也是协调器是客户端的分布式事务的一个例子。

扳手选择2PC + Paxos来减少一个节点故障的可能性。

相关问题