Apollo Federation 上的两个微服务之间的突变

Posted

技术标签:

【中文标题】Apollo Federation 上的两个微服务之间的突变【英文标题】:Mutation between two microservices on Apollo Federation 【发布时间】:2021-07-09 20:02:54 【问题描述】:

我正在使用 Apollo Federation 来处理大量 GraphQL 微服务。我想在关注用户时创建一个通知操作,所以我需要将一个突变从 UserService 发送到 NotificationService。我怎样才能做到这一点?

提前谢谢你!

【问题讨论】:

【参考方案1】:

我相信没有办法让突变在多个微服务中起作用。我能想到的唯一一件事就是总是在响应中解析一些字段并在 Notification MS 中创建一个解析器。但这听起来更像是一种 hack,而不是架构解决方案。

之所以这样做,是因为 apollo 没有任何事务系统,这在查询的情况下不需要,但在突变时确实需要。

您应该坚持微服务之间的默认消息交换,无论是事件总线(如 kafka 或 rabbitmq)还是简单的 http api。

【讨论】:

以上是关于Apollo Federation 上的两个微服务之间的突变的主要内容,如果未能解决你的问题,请参考以下文章

Apollo Federation 是不是支持代码优先方法?

在 Apollo GraphQl Federation 中,如何在没有 @external 指令的情况下应用 @requires 逻辑?

使用 apollo-federation 独立构建 GraphQL 服务

GraphQL Apollo Federation-JVM 中 @extends 类型的解析器问题

Graphql Apollo Federation - 基于实现服务解析计算域

Apollo federation 可以 2 个服务为相同的方法返回不同的模型