NestJS的緩存模塊天生支持Redis等緩存機制。以下通過一個示例,說明如何在NestJS中操作Redis。步驟如下:
先安裝運行Redis服務,步驟參見鏈接
新建nestjs項目:
nest new [項目名稱]
安裝cache相關依賴
npm install cache-manager
npm install -D @types/cache-manager
npm install cache-manager-redis-store --save
注冊Redis Store
打開src->app.module.ts,這里假設已經(jīng)在本地安裝啟動了Redis服務
import { Module, CacheModule } from '@nestjs/common';
import * as redisStore from 'cache-manager-redis-store';
imports: [
CacheModule.register({
store: redisStore,
host: 'localhost',
port: 6379,
}),
],
打開src->app.controller.ts, 使用Redis緩存服務
import {
Controller,
Get,
Res,
Req,
Inject,
CACHE_MANAGER,
} from '@nestjs/common';
import { Cache } from 'cache-manager';
fakeString = 'Hello World!';
@Get('cache-test')
async setGetSimpleString() {
const value = await this.cacheManager.get('my-string');
if (value) {
return {
data: value,
loadsFrom: 'redis cache',
};
}
await this.cacheManager.set('my-string', this.fakeString, { ttl: 20 });
return {
data: this.fakeString,
loadsFrom: 'fake database',
};
}
最后,訪問接口,打開Redis客戶端工具RedisNav,驗證結果:
![](/d/20211018/9e3675b986b0b54c19929b1c87b60eeb.gif)
參考:
https://www.learmoreseekmore.com/2020/12/nestjs-redis-cache.html
到此這篇關于NestJS+Redis實現(xiàn)緩存的文章就介紹到這了,更多相關Redis實現(xiàn)緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 詳解SpringBoot2.0的@Cacheable(Redis)緩存失效時間解決方案
- Redis 緩存實現(xiàn)存儲和讀取歷史搜索關鍵字的操作方法
- SpringCache 分布式緩存的實現(xiàn)方法(規(guī)避redis解鎖的問題)