Redis-Node 技术文档
2024-12-16 00:12:38作者:明树来
本文档将详细介绍如何安装、使用以及API调用方法,帮助用户更好地理解和运用redis-node模块。
1. 安装指南
要使用redis-node,首先需要通过npm进行安装:
npm install redis-node
2. 项目使用说明
redis-node 是一个功能完整的 Node.js Redis 客户端。以下是一个快速入门示例:
const redis = require("redis-node");
const client = redis.createClient(); // 创建客户端
client.select(2); // 选择数据库2
// 设置键值
client.set("hello", "world", function (err, status) {
if (err) throw err;
console.log(status); // true
});
// 使用哈希表
client.hmset("hash", { t: "rex", steg: "asaurus" }, function (err, status) {
if (err) throw err;
console.log(status); // true
});
// 支持事务
console.log("从支票账户转至储蓄账户。");
client.transaction(function () {
client.decrby("checking", 100, function (err, balance) {
if (err) throw err;
console.log("支票账户余额:" + balance);
});
client.incrby("savings", 100, function (err, balance) {
if (err) throw err;
console.log("储蓄账户余额:" + balance);
});
});
// 关闭连接
setTimeout(function () {
client.close();
}, 1000);
3. 项目API使用文档
以下是redis-node客户端的主要API参考。
redis.createClient(port, host, options)
创建一个新的客户端实例,连接到在指定host和port上运行的Redis服务器。
host
默认值为127.0.0.1
port
默认值为6379
- 可以传入一个选项哈希表。默认值为:
maxReconnectionAttempts
(10) 尝试重新连接到Redis服务器的次数。reconnectionDelay
(500) 重新连接尝试之间的等待时间(毫秒)。
Events
redis-node客户端会发出与Redis服务器连接相关的重要事件。可以绑定事件处理器到以下事件:
connected
客户端成功首次连接时发出。disconnected
客户端与Redis服务器断开连接时发出。reconnecting
客户端尝试重新连接前发出。reconnected
客户端成功重新连接时发出。noconnection
客户端放弃连接尝试时发出。connection error
连接过程中出现错误时发出。
Commands operating on all value types
以下是一些基本的Redis命令实现:
client.exists(key, callback)
检查键是否存在。client.del(key1, key2, ..., keyn, callback)
删除一个或多个键。client.type(key, callback)
返回存储在键中的值的类型。client.keys(pattern, callback)
查找与给定模式匹配的所有键。client.randomkey(callback)
返回一个随机键。client.rename(oldName, newName, callback)
重命名键。client.renamenx(oldName, newName, callback)
当新键名不存在时,重命名键。client.dbsize(callback)
返回当前数据库的键数。client.expire(key, ttl, callback)
设置键的过期时间。client.expireat(key, unixtime, callback)
设置键的过期时间为未来的Unix时间戳。client.ttl(key, callback)
返回键的剩余过期时间。client.select(dbIndex, callback)
选择一个数据库。client.move(key, dbIndex, callback)
将键从一个数据库移动到另一个数据库。client.flushdb(callback)
清除当前数据库的所有键。client.flushall(callback)
清除所有数据库的所有键。
Commands operating on strings
以下是对字符串操作的一些命令:
client.set(key, value, callback)
设置键值。client.get(key, callback)
获取键值。client.getset(key, value, callback)
设置键值并返回旧值。
更多命令和详细用法请参考项目文档和示例。
4. 项目安装方式
项目的安装方式已在安装指南中说明,通过npm命令进行安装:
npm install redis-node
通过上述指南和文档,用户应能够顺利安装并使用redis-node模块,实现与Redis服务器的交互。
热门项目推荐
相关项目推荐
- 国产编程语言蓝皮书《国产编程语言蓝皮书》-编委会工作区017
- nuttxApache NuttX is a mature, real-time embedded operating system (RTOS).C00
- qwerty-learner为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workersTSX027
- 每日精选项目🔥🔥 01.17日推荐:一个开源电子商务平台,模块化和 API 优先🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~026
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie045
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython05
- mybatis-plusmybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0108
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript09
热门内容推荐
最新内容推荐
项目优选
收起
Python-100-Days
Python - 100天从新手到大师
Python
267
55
国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
65
17
Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
196
45
openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
53
44
HarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
268
69
qwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
333
27
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
advanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
419
108
MateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
144
24
HarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
58
4