首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >与web服务的事务

与web服务的事务
EN

Software Engineering用户
提问于 2017-11-27 06:36:56
回答 1查看 98关注 0票数 1

我想知道如何实现与web服务的交易。

让我们以一个需要处理3项服务的在线商店为例:

  1. 库存管理SaaS
  2. 交付管理
  3. 支付网关

上述服务通过REST公开其服务。

如何实现类似于数据库事务的功能。要么全部要么什么都没有。

如果这些服务不公开API以回滚事务,那么解决方案是什么?

在无法使用回滚的情况下,使用每个服务的正确顺序是什么。我的意思是减少库存,然后发货,然后收取钱或其他订单?

EN

回答 1

Software Engineering用户

发布于 2017-11-27 08:09:55

如何实现类似于数据库事务的功能。

您可以使用分布式事务,但是可以使用你不会想要的。而且,更可能的是,你不需要这样做。

如果这些服务不公开API以回滚事务,那么解决方案是什么?

实际上,这很好,所以您不会搞砸分布式事务。处理这种事情的现代方法是使用最终一致性的概念。

通常是用萨格斯完成的。Saga是一种获取业务流程分布式协议的方法,同时也是处理失败的一种方法(我链接到的一个帖子中有一个很好的例子)。这并不是它们可以用某种方式实现的问题。它们可以有同步集中控制、异步集中控制或分布式

在没有回滚的情况下,使用每个服务的正确顺序是什么?

完全取决于你的域名。当从业务的角度来看不重要时,常识是从一个最容易回滚的操作开始,这样最危险的操作,也就是最复杂的回滚操作,将是最后一个。

下面是一个电子商务中的示例,使用上述的saga方法。

票数 4
EN
页面原文内容由Software Engineering提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://softwareengineering.stackexchange.com/questions/361309

复制
相关文章

相似问题

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