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

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

相关推荐
Kookoos1 小时前
ABP VNext + 多级缓存架构:本地 + Redis + CDN
redis·缓存·微服务·架构·abp vnext
长风破浪会有时呀2 小时前
Redis 命令总结
数据库·redis·缓存
GDAL3 小时前
Node.js 聊天内容加密解密实战教程(含缓存密钥优化)
缓存·node.js
@ chen3 小时前
Redis 实现分布式锁
redis·分布式
张先shen3 小时前
Redis的高可用性与集群架构
java·redis·面试·架构
原则猫4 小时前
jscodeshift 工程运用
前端·node.js
不简说4 小时前
Nodejs AI SDK盘点
javascript·node.js·openai
码里看花‌5 小时前
基于 Redis 实现高并发滑动窗口限流:Java实战与深度解析
java·开发语言·redis
程序员JerrySUN5 小时前
一文理解缓存的本质:分层架构、原理对比与实战精粹
java·linux·开发语言·数据库·redis·缓存·架构
cubicjin5 小时前
Redis面试题
数据库·redis·缓存