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

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

相关推荐
冰冰菜的扣jio1 小时前
Redis缓存中三大问题——穿透、击穿、雪崩
java·redis·缓存
阿里巴巴P8资深技术专家1 小时前
基于 Spring AI 和 Redis 向量库的智能对话系统实践
人工智能·redis·spring
oMcLin2 小时前
如何在 AlmaLinux 9 上配置并优化 Redis 集群,支持高并发的实时数据缓存与快速查询?
数据库·redis·缓存
洛阳纸贵2 小时前
Redis
数据库·redis·缓存
挺6的还4 小时前
13.持久化
redis
全栈前端老曹4 小时前
【包管理】read-pkg-up 快速上手教程 - 读取最近的 package.json 文件
前端·javascript·npm·node.js·json·nrm·package.json
沙白猿4 小时前
Redis报错:A bean with that name has already been defined in class path resource
spring boot·redis·mybatis
水冗水孚5 小时前
告别黑盒!手写Windows版简易NodeMON,学习文件监听代码修改与进程服务重启知识
node.js·express
IT 行者5 小时前
Spring Security 7 OAuth2 授权码分布式存储之Redis存储方案
redis·分布式·spring
程序员爱钓鱼5 小时前
Node.js 编程实战:测试与调试 —— 调试技巧与性能分析
前端·后端·node.js