阿波罗联盟上两个微服务之间的突变



我正在使用Apollo Federation来处理许多GraphQL微服务。我想在跟踪用户时创建一个NotificationService,所以我需要将一个突变从UserService发送到NotificationService。我怎样才能做到这一点?

提前谢谢!

我认为没有办法让突变在多个微服务之间发挥作用。我唯一能想到的是,总是解析一些字段作为响应,并在Notification MS中创建一个解析器。但这听起来更像是一个破解,而不是一个架构解决方案。

这样做尤其是因为apollo没有任何事务系统,这在查询的情况下是不需要的,但在突变的情况下需要。

您应该坚持微服务之间的默认消息交换,可以是事件总线(如kafka或rabbitmq(,也可以是简单的httpapi。

最新更新