nodejs操作redis总结
本文总结常见的使用node操作redis服务,redis的key是唯一的,如果一个key所对应的存储类型是string,则不能再次覆盖式设置key为hash;
1. 启动redis
这里我们使用docker方式搭建redis服务器
docker run -d --name redis -p 6379:6379 redis:2.8
2. 初始化
node操作redis需要引入redis包;
const redis = require('redis');
const client = redis.createClient( 6379, '127.0.0.1');
const util = require('util');
3. string(字符串)
一个字符串类型的值最大长度为512 M。
常见操作: get,set,mget,mset,incr(计数器++),decr(--)等等;
client.set('hello', 5, function(err, obj) {
client.incr('hello', function(err,data) {
client.get('hello', function(err,data) {
console.log(data); // 6
})
})
})
4. hash(哈希)
hash可用来存储对象,一个Redis 列表中最多可存储232-1(40亿)个元素
var obj = {
name:'sss',
age:223
}
client.hset("test", obj, function(err, obj) {
client.hgetall('test', (err, obj) => {
console.log(`hgetall:${JSON.stringify(obj)}`);
console.log(obj.age);
})
client.hget('test','name', function(err, name) {
console.log('hget test name');
console.log(name);
})
});
5. lists(列表)
对于lists,使用send_command进行操作;
队列操作
list,常用操作, list,常用操作, lpush(首位添加),rpush(末位添加),lset(修改首位值),lindex(删除首位元素),lpop(删除末位元素)
一个Redis 列表中最多可存储232-1(40亿)个元素
client.send_command('lset',['mylist',0,1], function(err,data) {
console.log(data); // OK
})
client.send_command('lpush',['mylist', 'one'], function(err, data) {
console.log(dada); //OK
}) // 使用命令行获取对应的索引下的结果
// lindex mylist 0 'one'
// lindex mylist 1 '1'
// lindex mylist 2 'xxx'
// lindex mylist 3 'xxx'
6. sets(集合)
sets 集合处理; 业务中用lodash进行交并补也是一个不错的选择。
常见操作: sadd、smembers、sinter(交)、sunion(并)、sdiff(补)、smove
集合中不允许重复成员的存在。当多次添加一个元素时,其结果会设置单个成员多次。一个Redis 集合中最多可包含232-1(40亿)个元素。
let db1 = ['mysql','redis'];
let db2 = ['mongo','redis'];
client.sadd('db1',db1, function(err,data) {
client.smembers('db1', function(err,data) {
console.log(toString.call(data)); // [object Array]
console.log('smemers:' + data); // 获取set中的成员, ['redis,mysql]
})
client.sadd('db2', db2, function(err, data) {
client.sinter('db1','db2', function(err,data) {
console.log('sinter:' + data) //交集: sinter:redis
});
client.sunion('db1','db2', function(err,data) {
console.log('sunion:' + data) // 并集: sunion:mongo,mysql,redis
});
client.sdiff('db1','db2', function(err,data) {
console.log('SDIFF:' + data) // 补集: SDIFF:mysql
})
})
});
7. 有序集合(SortedSets)
常用操作: zadd(设置元素), zrange(获取范围内的元素),zrank(获取指定元素的排名,从0开始), zscore(获取指定元素的score,用户指定的score)
client.zadd(['zdb',0,'mysql', 1,'mongo',2,'redis'], function(err, data) {
console.log(data); // 3
})
8. 事务
事务(multi命令): 批量执行所有的命令,并统一返回结果
client.multi()
.set('xiao','xing')
.get('xiao')
.exec(function(err,replies) {
console.log(replies); // [ 'OK', 'xing' ]
})
9. 订阅发布模式
redis的订阅发布模式可用来做类似kafka的消息推送;
使用list + redis的订阅发布模式可以构建一个不错的消息队列;
let sub = redis.createClient(6379, '127.0.0.1'); // 监听消费者
let pub = redis.createClient(6379, '127.0.0.1'); // 生产者 // 在sub开始监听时允许触发subscribe事件进行操作,类似连接数据库的connect事件
sub.on('subscribe', function(channel, count) {
console.log(`${channel}:${count}`); // test channel:1
pub.publish('test channel', 'channel message test')
})
sub.on('message', function(channel, message) {
console.log(`${channel}-message:${JSON.stringify(message)}`) // test channel-message:"channel message test"
})
sub.subscribe('test channel');
10. 对整个redis的所有客户端操作进行监听;
monitor事件可以监听到redis收到的所有客户端命令
client.monitor(function(err, res) {
console.log(res); // ok
})
client.on("monitor", function (time, args) {
console.log(time + ": " + util.inspect(args)); // 1556285641.395573: [ 'lindex', 'myset', '2' ]
});
nodejs操作redis总结的更多相关文章
- Nodejs操作redis
//npm install redis //首先加载node_redis模块 var redis = require('redis'); // 创建redis连接 var client = redis ...
- NodeJS操作Redis实现消息的发布与订阅
首先先说一下流程: 1.保存数据到Redis,然后将member值publish到 chat频道(publish.js功能) 2.readRedis.js文件此前一直在监听chat频道,readRed ...
- 架构设计之NodeJS操作消息队列RabbitMQ
一. 什么是消息队列? 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象. 消息队列(Message Queue)是一种应用间的通信 ...
- 在centos7中安装redis,并通过node.js操作redis
引言 最近在学习node.js 连接redis的模块,所以尝试了一下在虚拟机中安装cent OS7,并安装redis,并使用node.js 操作redis.所以顺便做个笔记. 如有不对的地方,欢迎大家 ...
- [Intel Edison开发板] 04、Edison开发基于nodejs和redis的服务器搭建
一.前言 intel-iot-examples-datastore 是Intel提供用于所有Edison开发板联网存储DEMO所需要的服务器工程.该工程是基于nodejs和redis写成的一个简单的工 ...
- Java Spring mvc 操作 Redis 及 Redis 集群
本文原创,转载请注明:http://www.cnblogs.com/fengzheng/p/5941953.html 关于 Redis 集群搭建可以参考我的另一篇文章 Redis集群搭建与简单使用 R ...
- Java中使用Jedis操作Redis(转载)
整理 1.字符串 添加:set keyname value 查询:get keyname 拼接:append keyname value 删除:del keyname 添加多个: mset keyna ...
- (转)Java中使用Jedis操作Redis
转自http://www.cnblogs.com/liuling/p/2014-4-19-04.html 使用Java操作Redis需要jedis-2.1.0.jar,下载地址:http://file ...
- Python—操作redis
Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ...
随机推荐
- CVE-2017-12149 JBOOS AS 6.X 反序列化漏洞利用
检测目录: 返回500 一般就是存在了. 下载工具: http://scan.javasec.cn/java/JavaDeserH2HC.zip 使用方法: javac -cp .:commons-c ...
- Heap
#include using namespace std; int heap[100010],cnt=0; void put(int x) { cnt++; heap[cnt]=x; int now= ...
- UE4学习心得:蓝图间信息通信的几种方法
蓝图间通信是一个复杂关卡能否正常运行的关键,笔者在这里提供几种蓝图类之间的信息交互方法,希望能对读者有所帮助. 1.类引用 这是最直接的一种蓝图类之间的信息交互方式.首先在Editor中创建2个Act ...
- angular 表单验证
最近在用angular写表单验证时 , 不小心把ng-model全替换删掉了, 然后发现之前写的验证都失效, 在查阅资料和反复修改摸索后, 发现angular中的表单验证, 都是基于ng-model的 ...
- 将Excel表中的数据导入到数据库
网上查到的有参考价值的就一家,自己调试发现可行.感谢原创文章:将Excel中数据导入数据库(一) using System; using System.Collections.Generic; usi ...
- Apache 、Tomcat、Nginx的区别
一. 定义: 1. Apache Apache HTTP服务器是一个模块化的服务器,可以运行在几乎所有广泛使用的计算机平台上.其属于应用服务器.Apache支持支持模块多,性能稳定,Apache本身是 ...
- 解决AES算法CBC模式加密字符串后再解密出现乱码问题
问题 在使用 AES CBC 模式加密字符串后,再进行解密,解密得到的字符串出现乱码情况,通常都是前几十个字节乱码: 复现 因为是使用部门 cgi AESEncryptUtil 库,找到问题后,在这里 ...
- 使用 Swoole 来加速你的 Laravel 应用
Swoole 是为 PHP 开发的生产级异步编程框架. 他是一个纯 C 开发的扩展, 他允许 PHP 开发者在 PHP 中写 高性能,可扩展的并发 TCP, UDP, Unix socket, HTT ...
- Tiny4412中断介绍
通过几天裸板驱动开发,今天对ARM的中断做一些简单总结,前面我们已经了解了ARM的7种异常模式,中断是异常模式的一种,在ARM中异常事件发生将会触发中断,但是,所有的中断都不能直接访问cpu,而是都统 ...
- Go 自带的 http/server.go 的连接解析 与 如何结合 master-worker 并发模式,提高单机并发能力
作者:林冠宏 / 指尖下的幽灵 掘金:https://juejin.im/user/587f0dfe128fe100570ce2d8 博客:http://www.cnblogs.com/linguan ...