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

Redis实现消息的发布订阅原理分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Redis实现消息的发布订阅原理分析

一、什么是发布和订阅

  • Redis 发布订阅 (pub/sub) 是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息。
  • 特点:Redis 客户端可以订阅任意数量的频道。
  • 这就好比粉丝们关注了我,当我写完文章发布的时候,你们打开CSDN也会接收到我写的文章。此时,我就是发送者(pub);粉丝们就是订阅者(sub)。

结构图如下:发布者发送自己的消息到redis服务器,订阅者从redis服务器中获取发布者发布的消息

在这里插入图片描述

二、Redis的发布和订阅

为了方便后面讲解发布和订阅命令行的使用,我先用两张图简单的介绍redis实现发布和订阅的整体流程。

客户端可以订阅频道如下图:

在这里插入图片描述

当给这个频道发布消息后,消息就会发送给订阅的客户端,如下图:

在这里插入图片描述

三、redis 发布订阅常用命令

下表列出了 redis 发布订阅常用命令:

在这里插入图片描述

四、命令实战

在演示redis消息的发布和订阅之前,我们需要打开两个客户端,一个充当消息发布者,一个充当消息接受者。

1、基本使用

先用一个客户端订阅频道csdn_blog,等待消息:

127.0.0.1:6379> SUBSCRIBE csdn_blog 
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "csdn_blog"
3) (integer) 1

接着一个客户端在csdn_blog频道发送消息hello,cabbage

127.0.0.1:6379> PUBLISH csdn_blog "hello,cabbage"
(integer) 1

最后接受者接收到消息:

1) "message" 
2) "csdn_blog"    # 接收消息所在的频道
3) "hello,cabbage"   # 接收到的消息

2、订阅符合要求的频道

订阅以csdn开头的频道,*表示任意字符

127.0.0.1:6379> PSUBSCRIBE csdn*
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "csdn*"
3) (integer) 1

发布者在两个频道发布消息:

127.0.0.1:6379> PUBLISH csdn_blog "hello"
(integer) 1
127.0.0.1:6379> PUBLISH csdn_sing "sing"
(integer) 1

最后订阅者接收到两个频道的消息:

1) "pmessage"
2) "csdn*"
3) "csdn_blog"
4) "hello"
1) "pmessage"
2) "csdn*"
3) "csdn_sing"
4) "sing"

3、查看活跃频道

订阅者订阅两条频道:

127.0.0.1:6379> SUBSCRIBE csdn_one csdn_two
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "csdn_one"
3) (integer) 1
1) "subscribe"
2) "csdn_two"
3) (integer) 2

发布者在三条频道发送消息:

127.0.0.1:6379> PUBLISH csdn_one "one"
(integer) 1
127.0.0.1:6379> PUBLISH csdn_two "two"
(integer) 1
127.0.0.1:6379> PUBLISH csdn_three "three"
(integer) 0

在发布者客户端显示活跃的频道:

127.0.0.1:6379> PUBSUB channels
1) "csdn_one"
2) "csdn_two"

五、发布订阅原理

每个Redis服务器进程都维持着一个表示服务器状态的redis.h/redisServer 结构, 结构的pubsub_channels属性是一个字典, 这个字典就用于保存订阅频道的信息,其中,字典的键为正在被订阅的频道, 而字典的值则是一个链表, 链表中保存了所有订阅这个频道的客户端

1、订阅频道原理

假设订阅频道前有如下图所示的频道和订阅该频道的客户端:从图中可以清楚的知道,channelA频道有三个人订阅;channelB频道没有人订阅;channelC频道有两个人订阅。

在这里插入图片描述

当客户端clientF调用SUBSCRIBE命令时,程序就将客户端和要订阅的频道在 pubsub_channels字典中关联起来。执行以下指令,对应的结果图为:

127.0.0.1:6379> SUBSCRIBE channelB channelC channelA

在这里插入图片描述

结论:通过pubsub_channels字典, 程序只要检查某个频道是否为字典的键,就可以知道该频道是否正在被客户端订阅; 只要取出某个键的值, 就可以得到所有订阅该频道的客户端的信息。

2、发布信息原理

原理说明:当调用PUBLISH channel message命令, 程序首先根据channel定位到字典的键, 然后将信息发送给字典值链表中的所有客户端。

对于上图来说,如果客户端channelA执行命令PUBLISH channelA “hello,cabbage”,那么clientAclientBclientCclientF这四个客户端都将接收到"hello,cabbage"信息,通过遍历订阅频道的所有客户端。

3、退订信息原理

原理:使用UNSUBSCRIBE命令可以退订指定的频道,这个命令执行的是订阅的反操作: 它从pubsub_channels字典的给定频道(键)中, 删除关于当前客户端的信息, 这样被退订频道的信息就不会再发送给这个客户端。

参考文章:http://t.zoukankan.com/rxbook-p-12652198.html

到此这篇关于Redis实现消息的发布订阅的文章就介绍到这了,更多相关Redis 消息发布订阅内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

Redis实现消息的发布订阅原理分析

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

下载Word文档

猜你喜欢

Redis实现消息的发布订阅原理分析

目录一、什么是发布和订阅二、Redis的发布和订阅三、redis 发布订阅常用命令四、命令实战1、基本使用2、订阅符合要求的频道3、查看活跃频道五、发布订阅原理1、订阅频道原理2、发布信息原理3、退订信息原理一、什么是发布和订阅Redis
2022-07-25

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

利用Redis实现分布式消息发布订阅在分布式系统中,消息的发布和订阅是常用的通信模式。在这个模式下,消息发布者将消息发送给一个或多个主题,订阅者则订阅感兴趣的主题,并接收相应的消息。为了实现这个模式,我们可以借助Redis这个高性能的内存数
利用Redis实现分布式消息发布订阅
2023-11-07

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

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

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

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

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

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

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

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

SpringBoot整合Redis实现消息发布与订阅的示例代码

能实现发送与接收信息的中间介有很多,比如:RocketMQ、RabbitMQ、ActiveMQ、Kafka等,本文主要介绍了Redis的推送与订阅功能并集成SpringBoot的实现,感兴趣的可以了解一下
2022-11-13

怎么用redis发布订阅方式实现简易的消息系统

这篇文章主要讲解了“怎么用redis发布订阅方式实现简易的消息系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用redis发布订阅方式实现简易的消息系统”吧!I. 基本使用1. 配置我
2023-06-19

C#如何用RabbitMQ实现消息订阅与发布

这篇文章给大家分享的是有关C#如何用RabbitMQ实现消息订阅与发布的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Fanout交换机模型扇形交换机,采用广播模式,根据绑定的交换机,路由到与之对应的所有队列。一个
2023-06-15

Kafka如何实现消息的发布和订阅功能

Kafka 是一个分布式的消息系统,它实现了消息的发布和订阅功能。在 Kafka 中,消息的发布和订阅是通过 Producer 和 Consumer 来实现的。发布消息:在 Kafka 中,消息的发布是由 Producer 来完成的。Pro
Kafka如何实现消息的发布和订阅功能
2024-03-06

Vue组件中事件总线和消息发布订阅的示例分析

小编给大家分享一下Vue组件中事件总线和消息发布订阅的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!简介主要介绍事件总线的定义和编写方法和Vue是如何实现
2023-06-29

C++利用模板实现消息订阅和分发功能

C++语言支持重载,模板,虚函数等特性,为编写高性能可扩展的程序提供了利器。本文就讲利用模板实现消息订阅和分发功能,感兴趣的小伙伴可以了解一下
2022-12-20

一文浅析vue中消息订阅与发布的使用方法

什么是消息订阅与发布?怎么使用?下面本篇文章给大家介绍一下vue中消息订阅与发布的使用方法,希望对大家有所帮助!
2023-05-14

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

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

编程热搜

目录