首页 > 数据库 >Redis组件介绍(六)

Redis组件介绍(六)

时间:2024-09-03 18:52:37浏览次数:3  
标签:退订 订阅 频道 Redis 介绍 发布 消息 组件

写在前面

今天学习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 定位到字典的键,然后将信息发送给字典值链表中的所有客户端。

标签:退订,订阅,频道,Redis,介绍,发布,消息,组件
From: https://www.cnblogs.com/cjybigdatablog/p/18395192

相关文章

  • Redis数据结构:Zset类型全面解析
    Redis数据结构:Zset类型全面解析Redis,作为一种高性能的键值对数据库,因其丰富的数据类型和高效的性能而受到了广泛的关注和使用。在Redis的五种主要数据类型中,Zset(有序集合)类型可能是最复杂,但也是最强大的一种。Zset不仅可以存储键值对,还可以为每个元素分配一个分数,然后根......
  • Redis备忘录
    基础知识缓存设计思想缓存的主要目的是提高数据访问速度,减少后端数据库的压力。设计时需要考虑:数据一致性:缓存与数据库中的数据需保持一致。缓存失效策略:如LRU(最近最少使用)等,以便有效管理缓存中的数据。数据过期:设置合理的过期时间,避免不必要的数据占用缓存空间。缓存开发......
  • Docker常用网路介绍
    说明Docker网络模式配置说明host模式–net=host容器和宿主机共享Networknamespace。container模式–net=container:NAME_or_ID容器和另外一个容器共享Networknamespace。kubernetes中的pod就是多个容器共享一个Networknamespace。none模式......
  • Docker内部组件介绍
    Docker的内部组件主要包括:DockerDaemon(dockerd):管理容器和镜像,处理DockerAPI请求。DockerClient(docker):与DockerDaemon交互的命令行工具。DockerImages:用于创建容器的不可变模板。DockerContainers:从镜像创建的运行实例。DockerRegistry:存储......
  • EasyCVR(V3.6.0)播放鉴权与播放限制时长的区别介绍
    有用户部署EasyCVR视频汇聚平台的新版本后(V3.6.0),发现新增了播放鉴权的配置项,于是咨询我们这个功能和之前的播放限制时长功能有何区别。今天我们就来解释下。其实这两个功能针对性不一样,播放鉴权是针对web页面,播放限制时长则是针对视频流。例如,将播放限制时长设置为2分钟,则代表该通......
  • Java实用类介绍
    实用类介绍(一)为什么需要枚举?Java枚举(enum)Java枚举是一个特殊的类,一般表示一组常量,比如一年的4个季节,一年的12个月份,一个星期的7天,方向有东南西北等。Java枚举类使用enum关键字来定义,各个常量使用逗号,来分割。例如定义一个颜色的枚举类。enumColor......
  • 智慧安防EasyCVR新版本(V3.6.0)播放鉴权与播放限制时长的区别介绍
    随着科技的飞速发展,视频技术已成为现代社会不可或缺的一部分,广泛应用于安防监控、娱乐传播、在线教育、电商直播等多个领域。EasyCVR视频汇聚平台作为视频技术的佼佼者,不断推陈出新,通过功能更新迭代,为用户提供更加高效、智能、稳定的视频解决方案。有用户部署EasyCVR视频汇聚平......
  • iconfont图标字体库详细介绍
    概述图标库在前端开发中应用十分广泛,图标库不仅会丰富美化界面的展示,语义化的图标库更能简洁明了地向用户传达某些信息,比如功能的特性和作用,引导用户,极大提高系统的易用性。在没有UI设计师的情况下,作为开发也可以自己打造图标库。而iconfont就是一种很好的选择。iconfon......
  • SpringBoot项目常用配置文件MybatisPlusConfig、RedisConfig、RedissonConfig、Swagge
    MybatisPlusConfig:@Configuration@MapperScan("com.yupi.usercenter.mapper")publicclassMybatisPlusConfig{@BeanpublicMybatisPlusInterceptormybatisPlusInterceptor(){MybatisPlusInterceptorinterceptor=newMybatisPlusInterc......
  • TS4+Vite+Vitest+Vitepress Vue3.3 自主打造媲美ElementPlus的组件库
    TS4+Vite+Vitest+VitepressVue3.3自主打造媲美ElementPlus的组件库这个问题看起来是想要创建一个类似ElementPlus的Vue组件库,并且使用TypeScript、Vite、Vitest和Vitepress进行开发。以下是一个简化的指南,用于创建一个自己的Vue组件库项目框架。安装必要的工具:npm......