Redis组件介绍(六)

news/2024/9/28 21:20:18

写在前面

今天学习redis最后的知识。

Redis 的发布与订阅

发布/订阅模式

Redis 提供了两种发布/订阅模式:

  • 基于频道 (Channel) 的发布/订阅
  • 基于模式 (Pattern) 的发布/订阅

相关命令

  1. 订阅频道

    subscribe channel [channel ...]
    

    订阅给定的一个或多个频道。

  2. 退订频道

    unsubscribe channel [channel ...]
    

    退订给定的频道。若没有指定频道,则默认退订所有频道。

  3. 发布消息

    publish channel message
    

    将消息发送给指定频道 channel。返回结果:接收到信息的订阅者数量,无订阅者返回 0。

  4. 查看活跃频道

    pubsub channels [argument [argument ...]]
    

    查看订阅与发布系统的状态。返回活跃频道列表(即至少有一个订阅者的频道,订阅模式的客户端除外)。

  5. 按模式订阅

    psubscribe pattern1 [pattern ...]
    

    订阅一个或多个符合给定模式的频道。每个模式以 * 作为匹配符;例如 shujia* 匹配所有以 shujia 开头的频道,如 shujia.javashujia.hadoop

  6. 按模式退订

    punsubscribe [pattern [pattern ...]]
    

    退订所有给定模式的频道。若 pattern 未指定,则退订所有模式;否则只退订指定的模式。

消息队列

在 Redis 中,List 数据类型可以用于排队数据,按照顺序取出,但无法精确获取(双端队列)。这种方式存在两个局限性:

  • 不能支持一对多的消息分发。
  • 如果生产者生成的速度远大于消费者的消费速度,易堆积大量未消费的消息。

角色

  • 发布者(Publisher):使用 PUBLISH 命令将消息发布到指定的频道。
  • 订阅者(Subscriber):使用 SUBSCRIBE 命令订阅一个或多个频道以接收消息。所有订阅同一频道的订阅者都会收到此消息。
  • 频道(Channel):频道是消息的通道,发布者通过指定频道来发布消息,订阅者通过订阅频道来接收相关消息。
  • 消息(Message):由发布者发送给订阅者的数据。

注意

  1. 订阅者使用 SUBSCRIBE 命令订阅频道后,将会一直等待新消息。可以使用 UNSUBSCRIBE 命令取消订阅。
  2. Redis 的发布订阅模式不保证消息的可靠传递。如果订阅者在消息发布之前已断开连接,则无法接收到已发布的消息。换句话说,如果先发布消息,再订阅频道,不会收到订阅之前就发布到该频道的消息!
  3. Redis 提供了其他相关命令和功能,如按模式订阅 (PSUBSCRIBE)、取消订阅 (UNSUBSCRIBE) 等。可以查阅 Redis 文档以获取更多信息。

请注意:在高吞吐量和大规模发布订阅场景下,Redis 的发布订阅模式可能不是最佳选择,可以考虑使用专门的消息队列系统来替代。

状态解释

localhost:7000> subscribe xiaohu1
Reading messages... (press Ctrl-C to quit)
1) "subscribe"  # 返回值类型:表示订阅成功!
2) "xiaohu1"   # 订阅频道的名称
3) (integer) 1  # 当前客户端已订阅频道的数量

示意图

  • 频道订阅:订阅频道时先检查字段内部是否存在;不存在则为当前频道创建一个字典,并创建一个链表存储客户端 ID;否则直接将客户端 ID 插入到链表中。
  • 取消频道订阅:取消时将客户端 ID 从对应的链表中删除;如果删除之后链表为空,则将会把这个频道从字典中删除。
  • 发布:首先根据 channel 定位到字典的键,然后将信息发送给字典值链表中的所有客户端。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/56224.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

prometheus学习笔记之集群内服务发现环境准备

一、环境介绍主要演示prometheus在k8s集群中如何通过服务自动去发现k8s集群自有服务及其他服务发现场景,后续会演示集群外部署prometheus自动发现k8s服务并获取数据创建监控使用的namespaceskubectl create ns monitoring配置docker可以下载镜像[root@k8s-master deploy]# cat…

使用列表推导式实现嵌套列表的平铺

先遍历列表中嵌套的子列表,然后再遍历子列表的元素并提取出来作为最终列表中的元素 a=[[1,2,3],[4,5,6],[7,8,9]] 通过列表推导式[c for b in a for c in b],我们首先将a中的每个子列表(这里用变量b表示) 遍历出来,然后对每个b进行遍历,提取出它的每个元素(这里用变量c表…

章10——面向对象编程(高级部分)——两种单例模式

代码如下: //单例模式 //instance--实例 //该篇中记录了饿汉模式和懒汉模式 public class HungryMan {public static void main(String[] args) {Single01.say();Single02.say();} }class Single01{//只能有instance这一个实例。private Single01(){System.out.println("…

列表操作示例

首先先定义一个列表,列表是写在[]里,用逗号隔开的,元素是可以改变的 列表的截取语法结构是:变量[头下标:尾下标] L = [abc,12,3.45,python,2.789] 输出完整列表 print(L) 输出列表的第一个元素 print(L[0]) 将列表的第一个元素修改为‘a’ L[0]=a 将列表的第2个元素到第3个…

如何设计真正的实时数据湖?

通过剖析“以湖代仓”观点的认知误区,本文提出了数据的流表二象性理论,并基于“流驱表”理念指出了湖仓融合的正确发展方向——利用流式计算加速湖内仓的数据流转,落地真正的实时数据湖。汽车制造行业在企业数据管理方案上的探索已有数十年之久,本文以辩证的视角回顾了这段…

【ELF系列】一文手撕ELF文件

一、ELF文件是什么二、ELF可重定位文件2.1 .shstrtab和.strtab2.2 .rel.text和.symtab2.3 .text节三、ELF可执行文件四、 参考原创 嵌入一下? 谦益行在一文了解ECU软件刷写文件HEX和S19格式 (qq.com)中介绍汽车控制器的刷写软件的格式,不管是编译生成的目标软件格式是哪种,同…

wsl2+arch+个人向美化

也算是入教arch了,本来想物理机的,但是又舍不得笔记本上的环境,刚好想着玩玩wsl2。到处缝缝补补也算是弄了个感觉能看的 最终效果图 图一内置主题图二p10k使用材料 终端直接用的是win的terminal,不是因为他善,只是我懒。喜欢捣鼓可以拿wezterm来 shell用的是on my zsh + p…