我有一个前端与主后端通信,该后端依次使用服务 A 和 B,使用 gRPC 调用-响应调用。 A 和 B 各自负责与它们交互的硬件组件以完成某些工作。两个硬件组件都会定期更改状态,这些状态需要转发到前端。
为了解决这个问题,我们团队正在讨论两种方法:
我对第二种方法有明显的偏好,但似乎很难让同事相信这种方法。也许我遗漏了一些东西,所以为了客观起见,我想知道您对这两种方法的看法。
我建议首先创建一份要求和注意事项列表。您不需要发布它们。就我个人而言,即使我从未发布过这些练习,我也总是会进行此练习,以确保我牢记所有问题。
您提到了对第三方身份复杂性的担忧,但没有提及解决方案 #2 的担忧。我认为这是该解决方案非常有利于解决方案 #2 的部分。
RabbitMQ 可以轻松实现以下功能:
group chats
message delivery check
receiving a message from the user while offline
receiving a message on all client applications at the same time (iOS, Android)
preventing unnecessary messages sending
message delivery optimization in case of disconnection from RabbitMQ, e.g. during Internet cut-off
PS。您是否正在考虑在解决方案一中为后端创建一个 API 以将状态发布到前端?