我们正在尝试通过Apollo联邦实现中继节点查询。由于Apollo不知道Relay,所以我们必须在某些服务(节点解析服务)中实现节点查询
interface Node {
id: ID!
}
type Query {
node(id: ID!): Node!
}
问题在于节点解析服务不知道任何实现类型,因为它们是在其他服务子图中定义的。
Apollo Gateway 向节点解析服务发送以下请求
{node(id:"dHlwZUZyb21BU2VydmljZTox"){__typename ...on TypeFromAnotherService{id __typename}}}
查询验证失败,因为服务不了解有关
TypeFromAnotherService
的任何信息。我们能够实现节点查询,因为我们在 ID 中编码了类型,但我们不知道如何修复验证。
有什么想法可以让中继节点查询与联邦一起工作吗?
我们通过实现一个独立的 Node Resolver 来解决这个问题。它执行以下操作:
TypeFromAnotherService
添加到架构中。我们正在考虑开源该服务,有人感兴趣吗?
Apollo 的联邦 GitHub 存储库上也有类似的未解决问题:https://github.com/apollographql/federation/issues/377 https://github.com/apollographql/federation/issues/1067
这些讨论给出了为什么这是一个悬而未决的问题背后的一些原因以及如何解决它的示例。此外,此示例可用于将 id 从节点映射到实体,但不是 Apollo 支持的功能:https://stackblitz.com/edit/nodemon-zbdwdj?file=README.md
如果这些不适用于您的用例,我会向最相关的 GitHub 问题添加反馈。
我也有同样的问题。我希望在后端获得 Apollo Federation 的优势,并在前端获得 Relay 的缓存处理。我能找到的最直接的方法是创建一个能够识别所有节点类型的节点服务。有了阿波罗联邦,这相对容易。如果您有兴趣,我写了一篇关于如何实现此功能的简短文章here!