什么是分布式事务

有这样一个需求:

小明有两个账户,分别位于A、B两个数据库中,小明需要将A中的资金转到B中。

我们如何实现?

按照下面的方式实现看看有没有问题。

  1. 连接数据库A,获取connA连接
  2. connA打开事务
  3. A库资金减少100
  4. 连接库B,获取connB连接
  5. connB打开事务
  6. B库资金增加100
  7. connA.commit()
  8. connB.commit()

上面操作,正常情况是没有问题。

第7步执行成功之后,网络出问题了,第8步会提交失败,此时的结果是:A库资金减少了100,B库资金却没有增加;这是一个网络问题导致了我们业务失败了,网络因素是程序不可控的一些因素,还有其他的比如运行到7之后,系统突然断电了,也会出现同样的结果。造成了数据错误,对业务影响也是比较大的。

 分布式事务可以这么理解:一个业务操作中,会包含很多子业务的,每个子业务都是独立的事务,我们需要考虑的是如何保证这些子业务都成功,或者都失败。

什么是最终一致性?

就拿上面的转账来说,A库的资金减少了,由于网络问题,操作B库的connB连接断开了,导致B库资金没有增加;网络问题是可以恢复了,如果网络恢复了,系统能够给B中资金加上,这样最终数据也是正确的;这中间有段时间AB库的资金是不一致的(A库减少了100,B库应该增加100却没有增加,数据是不一致的),但是最终某个时间点数据变为一致了。能够将不一致的时间降到最低是系统需要考虑的问题

分布式事务中,我们可以接受数据在某个时间段之内不一致,但是数据最终在某个时间点是一致的。

https://www.cnblogs.com/itsoku123/p/10875203.html

 

猜你喜欢

转载自www.cnblogs.com/ywsheng/p/11262102.html