1.22Node.js 中操作 Redis

redis操作.详见 18.redis基本操作-CSDN博客

在 Node.js 中操作 Redis,通常使用 redis 这个 npm 包。

首先,你需要安装 redis 包。可以通过 npm 来安装:

复制代码
npm install redis

基本使用

创建客户端

要开始与 Redis 交互,需要先创建一个客户端实例:

复制代码
const redis = require('redis');
const client = redis.createClient();

client.on('connect', () => {
    console.log('Connected to Redis');
});

默认情况下,createClient() 将尝试连接到运行在 127.0.0.1:6379 的 Redis 服务器。如果你的 Redis 服务器位于不同的主机或端口上,你可以传递相应的选项给 createClient() 方法。

设置和获取键值对
复制代码
client.set('key', 'value', (err, reply) => {
    if (err) throw err;
    console.log(reply); // 输出 "OK"
});

获取键对应的值:

复制代码
client.get('key', (err, reply) => {
    if (err) throw err;
    console.log(reply); // 输出 "value"
});
关闭客户端

当你完成与 Redis 的交互后,可以关闭客户端连接:

复制代码
client.quit();

异步/等待支持

从某些版本开始,redis 包提供了对异步/等待的支持,这使得代码更易于阅读和编写。例如:

复制代码
async function example() {
    await client.connect();
    const value = await client.set('key', 'value');
    console.log(value);
    
    const getValue = await client.get('key');
    console.log(getValue);
}

请注意,对于较新的版本(如 v4 及以上),redis 包引入了一些重大的变化,包括对 Promises 和 async/await 的原生支持。

五大数据结构实战

1. 字符串(String)
复制代码
// 设置值(过期时间 60 秒)
await redis.set('user:1', JSON.stringify({ name: 'Alice', age: 30 }), 'EX', 60);

// 获取值
const user = JSON.parse(await redis.get('user:1'));

// 原子操作:计数器
await redis.incr('page_views'); // 自增 1
await redis.incrby('page_views', 5); // 自增 5
2. 哈希(Hash)
复制代码
// 设置哈希字段
await redis.hset('user:2', 'name', 'Bob', 'age', 25);

// 获取单个字段
const name = await redis.hget('user:2', 'name');

// 获取所有字段
const user2 = await redis.hgetall('user:2'); // 返回 { name: 'Bob', age: '25' }
3. 列表(List)
复制代码
// 左插入
await redis.lpush('tasks', 'task1', 'task2');

// 右弹出(阻塞模式,超时 10 秒)
const task = await redis.brpop('tasks', 10);
4. 集合(Set)
复制代码
// 添加成员
await redis.sadd('tags:post1', 'js', 'node', 'redis');

// 获取所有成员
const tags = await redis.smembers('tags:post1');

// 判断成员是否存在
const hasTag = await redis.sismember('tags:post1', 'js');
  1. 有序集合(Sorted Set)

    // 添加成员(分数表示热度)
    await redis.zadd('trending_articles', 100, 'article1', 200, 'article2');

    // 获取热度最高的 10 篇文章
    const topArticles = await redis.zrevrange('trending_articles', 0, 9, 'WITHSCORES');

错误处理

不要忘记为你的 Redis 客户端添加错误处理程序:

复制代码
client.on('error', (err) => {
    console.error('Redis error:', err);
});

这将确保你能够捕获并处理任何可能出现的问题。

相关推荐
Gogo11213 小时前
构建高性能 Node.js 集中式日志体系 (下篇):Pino + PM2 + OpenSearch 代码落地实战
node.js
小岛前端4 小时前
Node.js 宣布重大调整,运行十年的规则要改了!
前端·node.js
前端付豪5 小时前
Nest 项目小实践之前端注册登陆
前端·node.js·nestjs
曲幽5 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
codingWhat1 天前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
ServBay1 天前
Node.js、Bun 与 Deno,2026 年后端运行时选择指南
node.js·deno·bun
码路飞1 天前
Node.js 中间层我维护了两年,这周终于摊牌了——成本账单算完我人傻了
node.js
None3212 天前
【NestJs】使用Winston+ELK分布式链路追踪日志采集
javascript·node.js
Dilettante2582 天前
这一招让 Node 后端服务启动速度提升 75%!
typescript·node.js
Mr_li3 天前
NestJS 集成 TypeORM 的最优解
node.js·nestjs