【问题标题】:Caching the axios httpService in NestJS在 NestJS 中缓存 axios httpService
【发布时间】:2020-06-23 04:29:17
【问题描述】:

在我们的应用程序中,我们使用 Axios HttpService 向第三方 api 发出一些请求。 因为 bij de api 返回的数据量很大,我们想缓存响应。 在文档中无法找到一些如何执行此操作的示例。 我目前这样做如下:

@Module({
  imports: [
    HttpModule,
    CacheModule.register({
      ttl: 15,
      store: redisStore,
      host: 'localhost',
      port: 6379,
    })
  ]
})
export class AppModule {}

我在全局范围内注册了 CacheModule。 然后将其导入我需要的模块中。

在我使用第三方 api 的服务中,我创建了一个拦截器并缓存响应。非常粗糙,仅用于测试。

constructor(private readonly httpService: HttpService,
              private readonly cache: CacheStore) {
    httpService.axiosRef.interceptors.response.use((response) => {
      cache.set(response.request.url, response.data);
      return response;
    }, error => Promise.reject(error));
  }

首先这不会运行,因为由于某种原因,CACHE_MANAGER 无法导入到 CacheModule 中。 其次,这是一种创建此类拦截器的 Node.js 方式,而不是 NestJS 方式。 但这是一种前进的方式,还是有更有效的方式,如果是,那是什么方式?

【问题讨论】:

    标签: caching axios nestjs


    【解决方案1】:

    CacheModule 在这里不是正确的工具,因为它意味着缓存 ingoing 请求(您的服务收到的请求,因此它不会再次处理它们并发回缓存结果) .

    您要做的是缓存 传出 请求(您的服务向 3rd-party 服务发出的请求)。由于神秘的原因,我也无法在 NestJS 文档中找到它,但您可以这样做:


    当您使用 Axios 时,您可以使用 axios-cache-adapter npm 包实现缓存。

    npm install --save axios-cache-adapter
    

    然后你需要创建一个适配器(最好在你的服务的构造函数中,见下面的注释):

    const cache = setupCache({
      maxAge: 3600 * 1000, // 60 minutes
    });
    

    并将此适配器作为 AxiosRequestConfig 的一部分与您的请求一起提供:

    const config = {
      adapter: this.cache.adapter,
    };
    this.httpService.get( url, config );
    

    你现在应该擅长一些缓存了!

    重要提示:

    • 应该使用缓存,并且可能只在 GET 请求上起作用
    • setupCache 函数只使用一次(例如在您的服务的构造函数中);如果你为每个请求创建一个缓存对象,这个缓存每次都是空的,违背了它的目的

    【讨论】:

      猜你喜欢
      • 2022-09-23
      • 2020-12-19
      • 2019-01-25
      • 2021-12-27
      • 2022-01-25
      • 2021-12-21
      • 2020-04-16
      • 2020-09-18
      • 2021-05-16
      相关资源
      最近更新 更多