本文总结常见的使用node操作redis服务,redis的key是唯一的,如果一个key所对应的存储类型是string,则不能再次覆盖式设置key为hash;

1. 启动redis

  1. 这里我们使用docker方式搭建redis服务器

     docker run -d --name redis -p 6379:6379 redis:2.8

2. 初始化

  1. node操作redis需要引入redis包;

     const redis = require('redis');
    const client = redis.createClient( 6379, '127.0.0.1');
    const util = require('util');

3. string(字符串)

  1. 一个字符串类型的值最大长度为512 M。

  2. 常见操作: 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(哈希)

  1. 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(列表)

  1. 对于lists,使用send_command进行操作;

  2. 队列操作

  3. list,常用操作, list,常用操作, lpush(首位添加),rpush(末位添加),lset(修改首位值),lindex(删除首位元素),lpop(删除末位元素)

  4. 一个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(集合)

  1. sets 集合处理; 业务中用lodash进行交并补也是一个不错的选择。

  2. 常见操作: sadd、smembers、sinter(交)、sunion(并)、sdiff(补)、smove

  3. 集合中不允许重复成员的存在。当多次添加一个元素时,其结果会设置单个成员多次。一个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)

  1. 常用操作: zadd(设置元素), zrange(获取范围内的元素),zrank(获取指定元素的排名,从0开始), zscore(获取指定元素的score,用户指定的score)

     client.zadd(['zdb',0,'mysql', 1,'mongo',2,'redis'], function(err, data) {
    console.log(data); // 3
    })

8. 事务

  1. 事务(multi命令): 批量执行所有的命令,并统一返回结果

     client.multi()
    .set('xiao','xing')
    .get('xiao')
    .exec(function(err,replies) {
    console.log(replies); // [ 'OK', 'xing' ]
    })

9. 订阅发布模式

  1. redis的订阅发布模式可用来做类似kafka的消息推送;

  2. 使用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的所有客户端操作进行监听;

  1. 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总结的更多相关文章

  1. Nodejs操作redis

    //npm install redis //首先加载node_redis模块 var redis = require('redis'); // 创建redis连接 var client = redis ...

  2. NodeJS操作Redis实现消息的发布与订阅

    首先先说一下流程: 1.保存数据到Redis,然后将member值publish到 chat频道(publish.js功能) 2.readRedis.js文件此前一直在监听chat频道,readRed ...

  3. 架构设计之NodeJS操作消息队列RabbitMQ

    一. 什么是消息队列? 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象. 消息队列(Message Queue)是一种应用间的通信 ...

  4. 在centos7中安装redis,并通过node.js操作redis

    引言 最近在学习node.js 连接redis的模块,所以尝试了一下在虚拟机中安装cent OS7,并安装redis,并使用node.js 操作redis.所以顺便做个笔记. 如有不对的地方,欢迎大家 ...

  5. [Intel Edison开发板] 04、Edison开发基于nodejs和redis的服务器搭建

    一.前言 intel-iot-examples-datastore 是Intel提供用于所有Edison开发板联网存储DEMO所需要的服务器工程.该工程是基于nodejs和redis写成的一个简单的工 ...

  6. Java Spring mvc 操作 Redis 及 Redis 集群

    本文原创,转载请注明:http://www.cnblogs.com/fengzheng/p/5941953.html 关于 Redis 集群搭建可以参考我的另一篇文章 Redis集群搭建与简单使用 R ...

  7. Java中使用Jedis操作Redis(转载)

    整理 1.字符串 添加:set keyname value 查询:get keyname 拼接:append keyname value 删除:del keyname 添加多个: mset keyna ...

  8. (转)Java中使用Jedis操作Redis

    转自http://www.cnblogs.com/liuling/p/2014-4-19-04.html 使用Java操作Redis需要jedis-2.1.0.jar,下载地址:http://file ...

  9. Python—操作redis

    Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ...

随机推荐

  1. java之Spring(IOC)注解装配Bean详解

    在这里我们要详细说明一下利用Annotation-注解来装配Bean. 因为如果你学会了注解,你就再也不愿意去手动配置xml文件了,下面就看看Annotation的魅力所在吧. 先来看看之前的bean ...

  2. 表示一个文件的 File 类型

    从本篇文章开始,我们将开启对 Java IO 系统的学习,本质上就是对文件的读写操作,听上去简单,其实并不容易.Java 的 IO 系统一直在完善和改进,设计了大量的类,也只有理解了这些类型被设计出来 ...

  3. NewLife.Net——管道处理器解决粘包

    Tcp网络编程,必须要解决的一个问题就是粘包,尽管解决办法有很多,这里讲一个比较简单的方法. 老规矩,先上代码:https://github.com/nnhy/NewLife.Net.Tests 一. ...

  4. linux下svn(subversion)服务端添加工程及配置权限

    linux下svn(subversion)服务端添加工程及配置权限 转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/9010507.html 此篇我只是将所做过的 ...

  5. -bash: ./switch.sh: /bin/bash^M: bad interpreter: No such file or directory

    问题: 偶然使用 windows 进行编写脚本.使用 wsl (windows subsystem for linux) 进行运行的时候,什么事情没有.但是当把脚本移植到远程服务器进行运行的时候,发现 ...

  6. python捕获异常、处理异常

    https://blog.csdn.net/jmilk/article/details/50047457

  7. eclipse下的tomcat配置https(最简单得配置https)

    近期公司列出一大堆的东西,其中包括https,啥也不想说,你们是无法理解的苦逼的我的 本文不是双向认证, 双向认证需要让客户端信任自己生成的证书,有点类似登录银行网站的情,如果想知道双向认证的同志可以 ...

  8. Linux内核调试方法

    内核配置选项中要使能CONFIG_MAGIC_SYSRQ选项,这样系统启动之后,会生成/proc/sysrq-trigger节点用于调试. 其次,可以在/etc/sysctl.conf中设置kerne ...

  9. SSH整合配置文件概括

    配置方式一:struts.xml, applicationContext.xml(hibernate.cfg.xml配置信息写入spring配置文件中) (版本号, struts2:2.3.15; s ...

  10. 二十六、Hadoop学习笔记————Hadoop Yarn的简介复习

    1. 介绍 YARN(Yet Another Resource Negotiator)是一个通用的资源管理平台,可为各类计算框架提供资源的管理和调度. 之前有提到过,Yarn主要是为了减轻Hadoop ...