spring - 异步微服务通信如何从UI的 Angular 表现得更好?

标签 spring angular asynchronous microservices event-driven

在我的 Angular UI 中,我从 API 网关调用端点,例如:

this.http.post(`/order`).subscribe(order => addNewOrderToList(order));

根据微服务的最佳实践,/order 处理程序应该发布一个事件供一个或多个微服务使用,而不是使用同步 REST 相互调用。因此,我编写了以下处理程序:

@RequestMapping
public Future<Order> addOrder() {
  CompletableFuture<Order> future = new CompletableFuture<>();
  // publish event
  // ...
  // wait for final event raised by a service.
  future.complete(createdOrder);
  return future;
}

从 UI 的 Angular 来看,在我的端点返回新订单之前,用户不会看到新订单吗?我觉得即使后端是异步的,UI 仍然是同步的。在这种情况下改进 UI 的最佳做法是什么?

最佳答案

在这种情况下,也许您应该做的是接受异步和最终一致性。

你的 HTTP 端点在被调用时实际上什么都不做,它只接受 UI 命令,并将它排入队列以供其他后端微服务最终处理它,对吧?

因此,您可能应该做的只是接受命令、验证它、将其加入队列并返回一个 HTTP 状态代码 202 Accepted给客户。您可以在响应中包含一个 ETA header ,或多或少地指示客户端何时可以轮询另一个端点以检查结果是否准备就绪。如果您正在关注 truly RESTful approach ,您可以包含指向客户端可用于在准备就绪时轮询结果的资源的链接。

您可能需要阅读以下文章:

关于spring - 异步微服务通信如何从UI的 Angular 表现得更好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47774291/

相关文章:

xml - spring servlet xml 顶部的声明是什么意思?

java - 如何将动态 Bean 参数注入(inject) Jersey 方法?

java - SpringMVC错误 "EL1044E: Unexpectedly ran out of input"

angular - 在 Angular 2 Material 中创建 md-cards 作为链接

javascript - 带有数组的 react 形式的primeng复选框

java - BufferedWriter 类型中的方法 write(int) 不适用于参数 (byte[])

Angular 忽略了 HTML 必需的验证?

c++ - 为什么从 `std::async` 阻塞返回的 future 的析构函数?

c# - 响应式用户界面 6 : How can I achieve same functionality of version 4 in version 6

asynchronous - 在 dart 的类中使用从 Future 返回的值