前言

  redis的空间键通知是在2.8.0版本以后加入的,客户端通过发布订阅的方式,订阅某个频道,接收通过某种方式影响redis中数据的事件.

目录:

  1.空间键事件分类

  2.如何启用redis的空间键通知

  3.命令行操作示例

  4.ioredis操作示例

1.空间键事件分类

  每一个影响redis数据空间的操作,都会产生两种事件,分别是key-space和key-event事件

  key-space是用来接收影响redis数据空间的操作的名称,如set, lpush

  key-event是用来接收受影响的键值名称

2.如何启用redis的空间键通知

  为了减少cpu性能的损耗,redis的空间键通知默认是关闭的(notify-keyspace-events为空),可以通过如下方式启用redis空间键通知:

  1)修改redis.conf中notify-keyspace-events的值,如:notify-keyspace-events 'K$'

  2)通过config set命令设置notify-keyspace-events的值,如:config set notify-keyspace-events 'K$'

  notify-keyspace-events的值为空,表示禁用空间键通知,若为非空,则启用该功能,非空可以由多个特定的字符组成,这些字符的含义如下:

    K Keyspace events, published with __keyspace@<db>__ prefix. 表示启用key-space事件

    E  Keyevent events, published with __keyevent@<db>__ prefix. 表示启用key-event事件

    g  一般性的指令,比如del(删除),expire(过期),rename(重命名)
    $  字符特定串命令

    l  列表特定命令

    s  集合特定命令

    h  hash特定命令

    z  有序集合特定命令

    x  过期事件

    e  驱逐事件

    A  g$lshzxe的别名

  例如设置notify-keyspace-events 'Kl' 表示仅仅对列表命令响应key-space事件(不响应key-event事件)

3.命令行操作示例

  首先设置notify-keyspace-events 'K$'

  在客户端A上执行:

127.0.0.1:6379> psubscribe __keyspace*@0__:test
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "__keyspace*@0__:test"
3) (integer) 1

  在客户端B上执行: 

127.0.0.1:6379> set test 1
OK

  则在客户端A上会输出:

1) "pmessage"
2) "__keyspace*@0__:test"
3) "__keyspace@0__:test"
4) "set"

  可见客户端A收到了key-space事件,而这个事件是通过客户端B set test 1产生的

4.ioredis操作示例

  客户端A:  

const Redis = require('ioredis')
const Koa = require('koa')
let app = new Koa()
let client = new Redis({host: 'localhost', port: 6379}) app.use(function* (next) {
client.setex('test:1111', 5, 'qqq')
}) app.listen(3000)

  客户端B:

const Koa = require('koa')
const Redis = require('ioredis')
const co = require('co') let app = new Koa() let client = new Redis({host: 'localhost', port: 6379})
let client2 = client.duplicate(); client.psubscribe('__keyspace@0__:test:*') client.on('pmessage', function (event, data, data1) {
let ttt = function* () {
let data2 = yield client2.get('qqqq')
}
co(ttt)
}) app.listen(3001)

  client.psubscribe('__keyspace@0__:test:*') 匹配所有对test:开头的键的操作

  注意: 这里如果想要使用redis的普通指令,则需要重新生成一个redis实例,这里可以通过client.duplicate()来生成一个配置相同的redis实例

  分别启动客户端A和客户端B,在浏览器中输入localhost:3000,可以看到客户端B输出如下信息:

__keyspace@0__:test:*
__keyspace@0__:test:1111
set

  

redis空间键详解的更多相关文章

  1. Redis AOF 持久化详解

    Redis 是一种内存数据库,将数据保存在内存中,读写效率要比传统的将数据保存在磁盘上的数据库要快很多.但是一旦进程退出,Redis 的数据就会丢失. 为了解决这个问题,Redis 提供了 RDB 和 ...

  2. [转]Reids配置文件redis.conf中文详解

    转自: Reids配置文件redis.conf中文详解 redis的各种配置都是在redis.conf文件中进行配置的. 有关其每项配置的中文详细解释如下: 对应的中文版解释redis.conf # ...

  3. [转]Redis内部数据结构详解-sds

    本文是<Redis内部数据结构详解>系列的第二篇,讲述Redis中使用最多的一个基础数据结构:sds. 不管在哪门编程语言当中,字符串都几乎是使用最多的数据结构.sds正是在Redis中被 ...

  4. Python操作redis字符串(String)详解 (三)

    # -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1.SET 命令用于设置 ...

  5. 探索Redis设计与实现6:Redis内部数据结构详解——skiplist

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

  6. 探索Redis设计与实现7:Redis内部数据结构详解——intset

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

  7. 探索Redis设计与实现5:Redis内部数据结构详解——quicklist

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

  8. 探索Redis设计与实现4:Redis内部数据结构详解——ziplist

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

  9. 探索Redis设计与实现3:Redis内部数据结构详解——sds

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

随机推荐

  1. JSK 糟糕的bug

    传送门 题目居然复制不了(QAQ) 分析 TrieJSK已经2比较详细了,就不再单独写博客了,此题相较于Trie模板有一点不同,此题要求比较前缀却没有规定前面是后面的前缀还是后面是前面的前缀,所以我们 ...

  2. 关于java中的编码问题

    ok,今天搞了一天都在探索java字符的编码问题.十分头疼.最后终于得出几点: 1.网上有很多博客说判断一个String的编码的方法是通过如下代码;但其实这个代码完全是错的,用一种编码decode后, ...

  3. Linux常用知识点汇总

    常用命令 1.ls 列出目录下的所有文件及文件夹 2.pwd 打印出当前所在目录 3. ./ 执行 .sh 文件命令 4.ip addr 查看ip地址 5.sudo  service network ...

  4. 【关于安装mysql5.6的一些问题总结】

    1:安装msyql5.6介质(mysql-5.6.24-winx64.msi)以后没有myslq服务: 解决: 管理员身份cmd进入bin目录: mysqld.exe -install Service ...

  5. 服务器控件button点击时执行脚本弹出提示对话框Button2.Attributes.Add("onclick","事件")

    <HTML> <HEAD>  <title>**********资料更新</title>  <meta content="Microso ...

  6. GTK+学习笔记(一)

    你将学到什么 如何实现弹出式菜单 菜单简介 菜单(GtkMenu)由菜单项(GtkMenuItem)构成,菜单项可以是任意构件比如按钮.菜单(子菜单) 菜单项的管理 菜单外壳(GtkMenuShell ...

  7. C#报算术运算导致溢出的错误

    如果是在fill datatable时报这个错,是因为所查询的数据中有在数据库中为NUMBER类型的字段,这种类型C#中不能识别,需TO_CHAR转换成字符型,就不会再报这个错了. e.g. SELE ...

  8. Openstack swift 学习笔记

    Swift 不是文件系统或者实时的数据存储系统,而是对象存储,用于长期存储永久类型的静态数据.这些数据可以检索.调整和必要时进行更新.Swift最适合虚拟机镜像.图片.邮件和存档备份这类数据的存储. ...

  9. 大融合——LCT维护子树信息

    题目 [题目描述] 小强要在 $N$ 个孤立的星球上建立起一套通信系统.这套通信系统就是连接 $N$ 个点的一个树.这个树的边是一条一条添加上去的.在某个时刻,一条边的负载就是它所在的当前能够联通的树 ...

  10. web综合案例04

    web综合案例02 web综合案例02 web综合案例04 待补充 ... ...