我想使用 redis 缓存进行分页,我使用 Node.js 作为我的后端,并且我使用 npm redis-scanner 包来扫描密钥。在这里,我无法转到特定键并从 redis 缓存中获取下 15 个键。我该怎么做?
问问题
1460 次
1 回答
0
您可以像这样使用ioredis:
const Redis = require("ioredis");
async getByCursor({ cursor }) {
const db = new Redis();
const stream = db.scanStream({ count: 5 }); // count = number of items to return per page
try {
const scan = () =>
new Promise((resolve, reject) => {
let items = [];
stream.on("data", (page) => {
items = [...items, page]; // page = ['key1', 'key2', etc.]
});
stream.on("end", () => {
resolve(items); // items = [['key1', 'key2'], ['key3', 'key4']]
});
});
const keys = await scan();
return Promise.all(
keys[cursor].map(async (key) => JSON.parse(await db.get(key)))
);
} catch (e) {
console.error(e);
return Promise.resolve([]);
}
}
或稍快:
async getByCursor({ cursor }) {
const stream = db.scanStream({ count: 5 });
try {
return new Promise((resolve, reject) => {
let pageCount = 0;
stream.on("data", (page) => {
pageCount = pageCount + 1;
if (pageCount == Number(cursor)) {
resolve(
Promise.all(
page.map(async (id) => unpack(await db.get(id)))
).catch((e) => {
console.error(e);
reject([]);
})
);
}
});
});
} catch (e) {
console.error(e);
}
使用游标
这里提供的光标值 1 例如作为参数或在调用“逐个光标”节点路由时为您提供前 5 个项目,下一页的值为 2 等。请注意,计数只是一个估计值,即您可以t 依赖它总是严格返回 5 个键(有关详细信息,请参阅下面的文档链接)。您可以查看https://react-query.tanstack.com/examples/load-more-infinite-scroll以获取前端解决方案,以获取要发送到路由的相关游标。
性能说明
与通过调用 db.get('*') 和/或过滤路由中的结果通过所有键获取所有项目相比,通过流获取键值对是非阻塞的。因此,建议将此实现用于生产。
更多 ioredis 文档
于 2021-08-11T22:31:25.250 回答