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

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

相关推荐
lThE ANDE1 小时前
最完整版Linux安装Redis(保姆教程)
linux·运维·redis
Meepo_haha2 小时前
配置 Redis
数据库·redis·缓存
不吃香菜学java4 小时前
Redis的java客户端
java·开发语言·spring boot·redis·缓存
2601_9498177210 小时前
基础篇:Linux安装redis教程(详细)
linux·运维·redis
zhensherlock11 小时前
Protocol Launcher 系列:Overcast 一键订阅播客
前端·javascript·typescript·node.js·自动化·github·js
indexsunny11 小时前
互联网大厂Java面试实战:核心技术与微服务架构在电商场景中的应用
java·spring boot·redis·kafka·maven·spring security·microservices
devilnumber15 小时前
Redis 使用过程中可能遇到的常见问题或 “坑”
数据库·redis·缓存
摇滚侠15 小时前
Redis 和 MySQL 数据同步方案,ElasticSearch 和 MySQL 数据同步方案
java·redis·mysql
人道领域15 小时前
【黑马点评日记03】实战:Redis缓存穿透,缓存击穿,缓存雪崩全解析
java·开发语言·jvm·redis·spring·tomcat
披着羊皮不是狼15 小时前
(9)批量生成文章并同步存入 MySQL 和 Redis
数据库·redis·mysql