我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Redis系列(八):发布与订阅

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Redis系列(八):发布与订阅

Redis系列(八):发布与订阅

Redis的发布与订阅,有点类似于消息队列,发送者往频道发送消息,频道的订阅者接收消息。

1. 发布与订阅示例

首先,在本机开启第1个Redis客户端,执行如下命令订阅blog.redis频道:

SUBSCRIBE "blog.redis"

然后,在本机开启第2个Redis客户端,执行相同的命令订阅blog.redis频道:

然后,开启第3个Redis客户端,执行如下命令往blog.redis频道发送消息:

PUBLISH blog.redis "redis-in-action-01"

查看客户端1和客户端2,分别看到如下信息:

3个客户端与频道的关系如下图所示:

可以通过INFO clients命令查看连接的客户端数:

2. 订阅/退订频道

2.1 订阅频道

Redis的SUBSCRIBE命令用来订阅频道,使用方式如下所示:

SUBSCRIBE "blog.redis"

如果是订阅多个频道,可以使用如下所示命令:

SUBSCRIBE "blog.redis" "blog.rocketmq"

Redis将所有频道的订阅关系保存在服务器状态的pubsub_channels字典里,字典的键是某个被订阅的频道,键对应的值是1个链表,链表里记录了所有订阅这个频道的客户端。

以上图为例,说明客户端1、客户端2正在订阅频道"blog.redis",客户端3、客户端4正在订阅频道“blog.rocketmq”。

如果此时有1个客户端5,执行了如下命令:

SUBSCRIBE "blog.rocketmq" "blog.java"

那么服务器状态保存的频道订阅关系将变为如下图所示:

2.2 退订频道

Redis的UNSUBSCRIBE命令用来退订频道,使用方式如下所示:

UNSUBSCRIBE "blog.redis"

如果是退订多个频道,可以使用如下所示命令:

UNSUBSCRIBE "blog.redis" "blog.rocketmq"

假设现在服务器状态保存的频道订阅关系如下图所示:

如果此时客户端5,执行了如下命令:

UNSUBSCRIBE "blog.rocketmq" "blog.java"

那么服务器状态保存的频道订阅关系将变为如下图所示:

3. 订阅/退订模式

3.1 示例

首先,启动1个Redis客户端,执行如下命令订阅模式“blog.r*”:

PSUBSCRIBE "blog.r*"

然后,启动另1个Redis客户端,执行PUBLISH命令往频道发送消息:

PUBLISH "blog.redis" "redis-in-action-01"

PUBLISH "blog.rocketmq" "rocketmq-in-action-01"

PUBLISH "blog.java" "java-in-action-01"

可以看到,第1次启动的客户端可以接收到前2条消息,因为频道"blog.redis"、"blog.rocketmq"匹配模式“blog.r*”:

但频道"blog.java"不匹配该模式,所以最后1次发送的消息,该客户端未接收到。

3.2 订阅模式

Redis的PSUBSCRIBE命令用来订阅模式,使用方式如下所示:

PSUBSCRIBE "blog.r*"

如果是订阅多个模式,可以使用如下所示命令:

PSUBSCRIBE "blog.r*" "blog.j?va" "blog.j[ae]va"

Redis将所有模式的订阅关系保存在服务器状态的pubsub_patterns属性里。

pubsub_patterns属性是1个链表,链表中的每个节点是1个pubsub_Pattern结构,这个结构的pattern属性记录被订阅的模式,client属性记录订阅模式的客户端。

以上图为例,说明客户端1正在订阅模式"blog.r*,客户端2正在订阅模式“blog.j?va”。

如果此时有1个客户端3,执行了如下命令:

PSUBSCRIBE "blog.j[ae]va"

那么服务器状态保存的模式订阅关系将变为如下图所示:

3.3 退订模式

Redis的PUNSUBSCRIBE命令用来退订模式,使用方式如下所示:

PUNSUBSCRIBE "blog.r*"

如果是退订多个模式,可以使用如下所示命令:

PUNSUBSCRIBE "blog.j?va" "blog.j[ae]va"

假设现在服务器状态保存的模式订阅关系如下图所示:

如果此时客户端3,执行了如下命令:

PUNSUBSCRIBE "blog.j[ae]va"

那么服务器状态保存的模式订阅关系将变为如下图所示:

4. 发送消息

如果,服务器状态保存的频道订阅关系如下图所示:

服务器状态保存的模式订阅关系如下图所示:

此时,如果1个Redis客户端执行了以下PUBLISH命令:

PUBLISH blog.redis "redis-in-action-01"

那么,服务器会执行以下2个动作:

  1. 将消息"redis-in-action-01"发送给频道“blog.redis”的所有订阅者
  2. 将消息"redis-in-action-01"发送给与频道“blog.redis”相匹配模式的订阅者

也就是说,消息"redis-in-action-01"不仅会发送给频道“blog.redis”的订阅者客户端1、客户端2,也会发送给与频道“blog.redis”相匹配的模式“blog.r*”的订阅者客户端5。

5. 查看订阅信息

可以使用Redis的PUBSUB命令来查看频道或者模式的相关信息。

5.1 查看被订阅的频道

如果想要查看被订阅的频道信息,可以使用命令PUBSUB CHANNELS [pattern],其中pattern参数是可选的:

  1. 如果不指定pattern参数,返回服务器当前被订阅的所有频道
  2. 如果指定pattern参数,返回服务器被订阅的频道中与pattern模式相匹配的频道

这个命令的实现原理是通过遍历服务器状态保存的pubsub_channels字典来实现的。

举个具体的例子,如果服务器状态保存的pubsub_channels字典如下所示:

那么执行命令PUBSUB CHANNELS的返回结果如下所示:

执行命令PUBSUB CHANNELS r*的返回结果如下所示:

5.2 查看频道的订阅者数量

如果想要查看频道的订阅者数量,可以使用命令PUBSUB NUMSUB [channel1 channel2 ... channeln]

这个命令的实现原理是通过遍历服务器状态保存的pubsub_channels字典来实现的,频道对应的订阅者链表的长度就是该频道的订阅者数量。

举个具体的例子,如果服务器状态保存的pubsub_channels字典如下所示:

那么执行命令PUBSUB NUMSUB blog.redis blog.rocketmq blog.java的返回结果如下所示:

5.3 查看被订阅模式的数量

如果想要查看被订阅模式的数量,可以使用命令PUBSUB NUMPAT

这个命令的实现原理是返回服务器状态保存的pubsub_patterns链表的长度。

举个具体的例子,如果服务器状态保存的pubsub_patterns链表如下所示:

那么执行命令PUBSUB NUMPAT的返回结果如下所示:

6. 总结

Redis的发布与订阅有点类似于消息队列的发布与订阅,主要包含以下7个命令:

  1. SUBSCRIBE
  2. UNSUBSCRIBE
  3. PSUBSCRIBE
  4. PUNSUBSCRIBE
  5. PUBSUB CHANNELS
  6. PUBSUB NUMSUB
  7. PUBSUB NUMPAT

这7个命令的核心都是基于存储在服务器状态的pubsub_channels字典和pubsub_patterns链表实现的。

7. 参考

黄健宏 《Redis设计与实现》


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Redis系列(八):发布与订阅

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis系列(八):发布与订阅

Redis的发布与订阅,有点类似于消息队列,发送者往频道发送消息,频道的订阅者接收消息。1. 发布与订阅示例首先,在本机开启第1个Redis客户端,执行如下命令订阅blog.redis频道:SUBSCRIBE "blog.redis"然后,在本机开启第2个Re
Redis系列(八):发布与订阅
2015-06-07

redis的发布订阅

简介进程间的消息通信模式: 发送者(pub)发送消息,订阅者(sub)接收消息示例,订阅多个127.0.0.1:8686[1]> SUBSCRIBE c1 c2 c3Reading messages... (press Ctrl-C to quit)1) "s
redis的发布订阅
2020-06-08

JAVA 实现 Redis 发布订阅

Redis 发布订阅 发布订阅:消息发布者发布消息 和 消息订阅者接收消息,两者之间通过某种媒介联系起来 例如订杂志,当自己订阅了爱格杂志,每个月会发刊一本。到发布的时候派送员将杂志送到自己手上就能看到杂志内容。只有我们订阅了该杂志才会
2023-08-18

Spring boot+redis实现消息发布与订阅

一.创建spring boot项目 org.springframework.boot spring-boot-starter-data-redis org.spr
Spring boot+redis实现消息发布与订阅
2017-09-29

【赵强老师】Redis的消息发布与订阅

Redis 作为一个publish/subscribe server,起到了消息路由的功能。订阅者可以通过subscribe和psubscribe命令向Redis server订阅自己感兴趣的消息类型,当发布者通过publish命令向Redis server发
【赵强老师】Redis的消息发布与订阅
2021-07-29

Redis | 第8章 发布订阅与事务《Redis设计与实现》

目录前言《Redis常用命令及示例总结(API)》:https://www.cnblogs.com/dlhjw/p/15639773.html1. 发布订阅1.1 频道的订阅与退订1.2 模式的订阅与退订1.3 发送消息1.4 查看订阅消息2. 事务2.1 事
Redis | 第8章 发布订阅与事务《Redis设计与实现》
2016-06-20

怎么利用Jedis实现Redis的订阅与发布

怎么利用Jedis实现Redis的订阅与发布?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是Redis发布订阅Redis发布订阅是一种消息通信模式,发送者通
2023-05-31

Redis系列(五)发布订阅模式、主从复制和哨兵模式

NoSQL 开发中或多或少都会用到,也是面试必问知识点。最近这几天的面试每一场都问到了。但是感觉回答的并不好,还有很多需要梳理的知识点。这里通过几篇 Redis 笔记整个梳理一遍,后面再加上面试题。Redis 系列:1. Redis系列(一)Redis入门2.
Redis系列(五)发布订阅模式、主从复制和哨兵模式
2015-03-21

redis怎么实现队列阻塞、延时、发布和订阅

这篇“redis怎么实现队列阻塞、延时、发布和订阅”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“redis怎么实现队列阻塞、
2023-07-02

Redis发布/订阅模式实例分析

这篇文章主要讲解了“Redis发布/订阅模式实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis发布/订阅模式实例分析”吧!Redis发布/订阅应用发布订阅(pub/sub)是一
2023-06-27

如何利用Redis实现分布式消息发布与订阅

如何利用Redis实现分布式消息发布与订阅引言:在分布式系统中,消息发布与订阅是一种常见的通信模式,可以实现不同模块之间的解耦。Redis作为一种高性能的键值对存储系统,可以用来实现分布式消息发布与订阅功能。本文将介绍如何使用Redis来实
如何利用Redis实现分布式消息发布与订阅
2023-11-07

Python操作redis的订阅发布功能

安装redis-serveryum -y install gcc gcc-c++    #安装编译工具cd /optwget -c http://download.redis.io/releases/redis-3.0.5.tar.gz  
2023-01-31

编程热搜

目录