Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update caching documentation for usage of Keyv with CacheModule #3135

Open
1 of 5 tasks
nickhall opened this issue Nov 7, 2024 · 2 comments
Open
1 of 5 tasks

Update caching documentation for usage of Keyv with CacheModule #3135

nickhall opened this issue Nov 7, 2024 · 2 comments

Comments

@nickhall
Copy link

nickhall commented Nov 7, 2024

I'm submitting a...

  • Regression
  • Bug report
  • Feature request
  • Documentation issue or request (new chapter/page)
  • Support request => Please do not submit support request here, instead post your question on Stack Overflow.

Current behavior

https://docs.nestjs.com/techniques/caching#different-stores

In order to use different stores with the CacheModule, the docs say to use the cache-manager package with cache-manager-redis-yet

https://www.npmjs.com/package/cache-manager-redis-yet

If you check this package, though, you'll notice that the package has a deprecation message:

This package has been deprecated
Author message:
With cache-manager v6 we now are using Keyv

On top of that, cache-manager is now cacheable, and they seem to be moving to a new package: https://github.com/jaredwray/cacheable

I would like to avoid using deprecated packages, but it's unclear how to use Keyv to set up the cache. The Keyv project site has a tutorial about setting it up to work with Nest, but this does not integrate with the CacheModule system and loses the included benefits.

Expected behavior

I would like to see the docs updated with official guidance around how to integrate with external cache providers

What is the motivation / use case for changing the behavior?

This should make it easy for people who are new to Nest to set up basic functionality.

@michaelarnauts
Copy link

Some things I noticed after upgrading to @nestjs/cache-manager 3.0.0-next.0.

import { Cache } from '@nestjs/cache-manager';

export class Service {
  constructor(
    private cacheManager: Cache,
  ) {}
}
  • I've used the following to register KeyvRedis as a Cache, but since my username/password were empty and host was localhost, you could as well just use new KeyvRedis(). It seems to be using localhost:6379 as default.
    CacheModule.registerAsync({
      imports: [ConfigModule],
      useFactory: async (configService: ConfigService) => {
        if (configService.get('REDIS_HOST')) {
          const url = new URL('redis://');
          url.host = configService.getOrThrow('REDIS_HOST');
          url.port = configService.getOrThrow('REDIS_PORT');
          url.username = configService.getOrThrow('REDIS_USERNAME');
          url.password = configService.getOrThrow('REDIS_PASSWORD');
          return {
            stores: [new KeyvRedis(url.toString())],
          };
        }
        return {};
      },
      inject: [ConfigService],
      isGlobal: true,
    }),

@crappylime
Copy link

Another breaking change with the next pre-release is that store is not supported anymore as visible here.

I'd recommend including the return type in the factory to understand what needs to be returned as otherwise it doesn't throw an error:

import { CacheManagerOptions } from '@nestjs/cache-manager';

useFactory: async (config: ConfigService): Promise<CacheManagerOptions> => {

Additionally, stores accepts the Keyv instance, not only the storage adapter instance (such as new KeyvRedis()), which is great as it allows adding listeners before passing to stores:

  const store = new KeyvRedis(redisOptions);
  const keyv = new Keyv({ store, ttl });
  keyv.on('error', (error) => console.error('Redis client error:', error));

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants