微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有没有办法在 Apollo Gateway 和联合服务之间添加缓存?

如何解决有没有办法在 Apollo Gateway 和联合服务之间添加缓存?

我正在使用 Apollo Federation,但我有一个关于缓存的问题。

现在我有一个这样的查询,我想在哪里找到帖子的作者:

query GetPost {
  post(id: "123") {
    id
    author {
      id
      name
    }
  }
}

发布是一种服务,作者是另一种服务。 “id”包含在 post 模型中,因为这是使用客户端 apollo 库时的预期。

当该查询运行时,会在内部发出两个请求:每个服务一个

现在,生成的对 post 服务的请求(由网关)非常简单,如下所示:

query {
  post(id: "123") {
    id
  }
}

我每分钟都会收到数千个这样的信息,并希望将它们缓存起来。显然,通过 ID 获取帖子的 ID 永远不会改变,所以每次这样的请求都是一种浪费。

有没有办法在网关端缓存这个请求?这样它就不会向邮政服务发出请求。

解决方法

根据 Apollo docs,您可以通过扩展 RemoteGraphQLDataSource 类来自定义用于从实现服务中检索数据的提取器。自定义提取器可以是实现提取规范的任何函数,在本例中,我使用 node-fetch-cache 将查询持久化到网关上的磁盘。

const { ApolloGateway,RemoteGraphQLDataSource } = require("@apollo/gateway");

class CachingDataSource extends RemoteGraphQLDataSource {
    fetcher = require('node-fetch-cache')('./locaCache');
}

const gateway = new ApolloGateway({
    serviceList: [
        { name: "post",url: "http://posts.service" },{ name: "author",url: "http://author.service" },],buildService({ name,url }) {
        if (url === "http://posts.service") {
            return new CachingDataSource({ url,name });
        } else {
            return new RemoteGraphQLDataSource({
                url,name
            });
        }
    },});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。