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);
});

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

相关推荐
自不量力的A同学22 分钟前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
fengxin_rou29 分钟前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
是阿楷啊2 小时前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试
笨蛋不要掉眼泪2 小时前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
ALex_zry14 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
乔江seven17 小时前
【Flask 进阶】3 从同步到异步:基于 Redis 任务队列解决 API 高并发与长耗时任务阻塞
redis·python·flask
这周也會开心18 小时前
Redis与MySQL回写中的数据类型存储设计
数据库·redis·mysql
shuair18 小时前
redis缓存预热、缓存击穿、缓存穿透、缓存雪崩
redis·spring·缓存
shuair19 小时前
guava布隆过滤器及cuckoo过滤器
redis·guava
上架ipa19 小时前
redis图形化客户端功能对比
redis·缓存