- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 spring cloud 来实现我的微服务系统,一个售票平台。场景是,有一个zuul代理,一个eureka注册中心,以及3个服务:用户服务、订单服务和票务服务。服务使用伪装声明式 REST 客户端来相互通信。
现在有一个买票的功能,主要流程如下:
1. 订单服务接受创建订单的请求
2. 订单服务创建处于待处理状态的订单实体。
3. 订购服务调用用户服务处理用户支付。
4.订单服务调用票务服务更新用户票证。
5.订单服务将订单实体更新为FINISHED。
我想用 Hystrix Fallback
来实现交易。例如,如果支付过程已完成,但在票务移动过程中发生了一些错误。如何查看用户付款和订单状态。因为用户付款是在其他服务中。
以下是我目前的解决方案,我不确定它是否合适。或者有没有其他更好的方法来做到这一点。
首先,OrderResource:
@RestController
@RequestMapping("/api/order")
public class OrderResource {
@HystrixCommand(fallbackMethod = "createFallback")
@PostMapping(value = "/")
public Order create(@RequestBody Order order) {
return orderService.create(order);
}
private Order createFallback(Order order) {
return orderService.createFallback(order);
}
}
@Service
public class OrderService {
@Transactional
public Order create(Order order) {
order.setStatus("PENDING");
order = orderRepository.save(order);
UserPayDTO payDTO = new UserPayDTO();
userCompositeService.payForOrder(payDTO);
order.setStatus("PAID");
order = orderRepository.save(order);
ticketCompositeService.moveTickets(ticketIds, currentUserId);
order.setStatus("FINISHED");
order = orderRepository.save(order);
return order;
}
@Transactional
public Order createFallback(Order order) {
// order is the object processed in create(), there is Transaction in create(), so saving order will be rollback,
// but the order instance still exist.
if (order.getId() == null) { // order not saved even.
return null;
}
UserPayDTO payDTO = new UserPayDTO();
try {
if (order.getStatus() == "FINISHED") { // order finished, must be paid and ticket moved
userCompositeService.payForOrderFallback(payDTO);
ticketCompositeService.moveTicketsFallback(getTicketIdList(order.getTicketIds()), currentUserId);
} else if (order.getStatus() == "PAID") { // is paid, but not sure whether has error during ticket movement.
userCompositeService.payForOrderFallback(payDTO);
ticketCompositeService.moveTicketsFallback(getTicketIdList(order.getTicketIds()), currentUserId);
} else if (order.getStatus() == "PENDING") { // maybe have error during payment.
userCompositeService.payForOrderFallback(payDTO);
}
} catch (Exception e) {
LOG.error(e.getMessage(), e);
}
order.setStatus("FAILED");
orderRepository.save(order); // order saving is rollbacked during create(), I save it here to trace the failed orders.
return order;
}
}
@HystrixCommand
在 OrderResource.create(order)
方法,使用 fallback
功能。 order
OrderResource.create(order)
中使用的实例将在回退功能中再次使用。虽然这个order
的坚持将被回滚。但本实例中的数据仍可用于检查运行情况。 ticketCompositeService
和 userCompositeService
是一个假客户。假客户端方法payForOrder()
,还有一种方法payForOrderFallback()
为后备。 try/catch
为 ticketCompositeService
和 userCompositeService
调用,以确保订单将以“失败”状态保存。 userCompositeService.payForOrderFallback(payDTO);
中出现错误,则不会调用以下复合服务调用。
最佳答案
在 Hystrix 回退中编写补偿逻辑是危险的,因为不涉及持久性。
这种方法不提供任何弹性。由于涉及外部方,因此数据库的 ACID 保证在这里是不够的,而且 Hystrix 回退不会保护您免受任何不属于您的代码的影响。
例如,如果您的解决方案在付款完成后遇到中断(例如,停电或简单的 kill -9
),您将丢失订单和补偿逻辑,这意味着订单将被支付,但不会出现在数据库中。
更具弹性的方法将涉及用于事件驱动交付的任何流行消息代理和处理逻辑中的一些重复数据删除,以确保在中断后重新交付事件时的一次性服务质量。
关于spring-cloud - 如何基于Spring Cloud架构师实现带有hystrix fallback的分布式事务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44065186/
我试图找出 asp-fallback-test-property 和 asp-fallback-test 之间的区别,两者都使用该属性来确定是否回退。它们是相同还是有区别 下面的链接没有回答差异,而且
我有以下路由器对象 const appRoutes: Routes = [ { path: '', redirectTo: '/', pathMatch:'full'}, { path: ''
我是微服务的新手,我一直遇到挑战,我认为这些挑战很小但无法解决。来 self 的 Eureka 注册服务 @RestController @RequestMapping("/users") publi
所以如果你有这样的代码: background: url('image.png'); background: -webkit-gradient(linear, left top, left botto
我怎么知道在使用 FALLBACK 时我是否真的需要返回一个 l 值? ? 我正在使用 return-rw但我只想使用 return在可能的情况。我想跟踪我是否真的修改过 %!attrs或仅在 FAL
我有以下使用流类型的函数 push = (pathname: string, data?: Object) => { const history = [...this.state.hist
正如 Google 对页面性能的建议,我将 webp 图像添加到我的项目中。但是我知道 Safari 不支持这种图像类型,所以我试图为 Safari 用户添加后备 png 图像。 我使用了下面的设置。
我正在尝试将SQL2008支持添加到.NET 2.0应用程序。但是,我的独特之处是某些用户仍将使用SQL2005,并且我不想要求他们安装SQL2008客户端组件。 我为SQL2008所需的实际DLL集
正如 Google 对页面性能的建议,我将 webp 图像添加到我的项目中。但是我知道 Safari 不支持这种图像类型,所以我试图为 Safari 用户添加后备 png 图像。 我使用了下面的设置。
我目前正在微调一个相对较大的项目的 log4j 配置。目前我还没有为所有可以创建日志条目的位置配置日志级别。 我希望 log4j 有某种后备附加程序来记录未配置其他附加程序的所有消息。因此,如果我有一
我在我的 javascript 中使用选项,如果它不存在,它会回退到默认值: var tabActive = typeof data.tabActive !== 'undefined' ? data.
我最近将 xcode 更新到最新的 5.1.1,随后将 ios 支持升级到 7.1(从 7.0)。 我有一些中文字符的自定义字体,在我更新之前可以正常使用,但现在根本无法使用! 这是它之前工作的图片:
我正在编写一个必须显示图像并可能加载图像的应用程序。所以我想知道是否有让 QGraphicsScene 使用 OpenGL 的正确方法,如果失败,请使用软件渲染器。 我已经阅读了文档,但是如果设置视口
为什么在使用 hystrix 库时在后备方法中进行数据库调用是一种不好的做法? @HystrixCommand(fallbackMethod ="fallBackMethod") public Dou
我想使用 fallback.io 中的 fallback.js,所以我使用了 github 中的文档。问题是它只适用于 css 和字体文件,但不适用于我的所有 js 脚本。 fallbac
我有一组类,每个类都需要在某个时候决定它们应该在内部使用两种或三种方法中的哪一种来在外部实现相同的功能。理想情况下,这应该包括回退功能,如果 ApproachA 失败,它会失败以尝试 Approach
我想在失败的情况下使用回退,因此“打开”状态下的行为应该是调用回退而不是抛出异常。 问题是回退在“关闭”状态下被调用,而对于“打开”状态我仍然得到异常。这是预期的行为吗?无法获得我正在寻找的东西? 我
我正在尝试将 xsl:fallback 合并到我的样式表中。我正在使用 Saxon9.5.1.23-HE。 我在调用的命名模板中尝试了这段代码: blabla
我玩 asp core 并希望回退到我的本地 bootswatchSlate.css,它位于 wwwroot 文件夹中,只有当我无法从 cdn 访问 bootstrap 时: 布局.cshtml 虽
我想通过使用两个后备将字符串输出到呈现的 HTML。 我的错字是在顶级页面(我网站的根页面)定义的,并传递到较低级别的所有页面。 结构: 主页 1 级页面 2 级页面 文件的常规输出: 该字符串来自
我是一名优秀的程序员,十分优秀!