我想知道如何实现与web服务的交易。
让我们以一个需要处理3项服务的在线商店为例:
上述服务通过REST公开其服务。
如何实现类似于数据库事务的功能。要么全部要么什么都没有。
如果这些服务不公开API以回滚事务,那么解决方案是什么?
在无法使用回滚的情况下,使用每个服务的正确顺序是什么。我的意思是减少库存,然后发货,然后收取钱或其他订单?
发布于 2017-11-27 08:09:55
如何实现类似于数据库事务的功能。
您可以使用分布式事务,但是可以使用你不会想要的。而且,更可能的是,你不需要这样做。
如果这些服务不公开API以回滚事务,那么解决方案是什么?
实际上,这很好,所以您不会搞砸分布式事务。处理这种事情的现代方法是使用最终一致性的概念。
通常是用萨格斯完成的。Saga是一种获取业务流程分布式协议的方法,同时也是处理失败的一种方法(我链接到的一个帖子中有一个很好的例子)。这并不是它们可以用某种方式实现的问题。它们可以有同步集中控制、异步集中控制或分布式。
在没有回滚的情况下,使用每个服务的正确顺序是什么?
完全取决于你的域名。当从业务的角度来看不重要时,常识是从一个最容易回滚的操作开始,这样最危险的操作,也就是最复杂的回滚操作,将是最后一个。
下面是一个电子商务中的示例,使用上述的saga方法。
https://softwareengineering.stackexchange.com/questions/361309
复制相似问题