• Redis数据库的发布与订阅(详细讲解)


    一、实验目的

    了解Redis数据库的发布与订阅

    二、发布与订阅

    1.1什么是发布和订阅

    发布订阅是一对多的关系,需要有信息的发布者和消息的收听者。

    发布者:提供某个内容或主题,把内容信息发送给多个对此内容感兴趣的订阅者
    订阅者:对某个内容感兴趣,需要实时获取新的内容,只要关注的内容有变化就能立即得到通知。

    发布订阅应用在即时通信应用中较多,比如网络聊天室、实时广播、实时提醒,滴滴打车软件的抢单,外卖的抢单,微信中关注公众号/订阅号,公众号/订阅号发布的文章和信息等,也都可以使用发布订阅实现。

    1.2Redis的发布和订阅

    Redis 发布订阅 (pub/sub) 也是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息。Redis 客户端可以订阅任意数量的频道。在一些系统中,Redis可以作为简易的单项消息通信服务器,提供数据群发功能。
    请添加图片描述

    三、代码实现

    2.1常用命令

    publish 发布消息

    publish channel(频道名称) message
    作用:将 message 消息发送到 channel 频道。message 是要发送的消息,channel是自定义的频道名称,唯一标识发布者

    subscribe 订阅频道

    语法:subscribe channel[channel…]
    作用:订阅一个或多个频道的信息 返回值:订阅的消息

    unsubscribe 退订频道

    语法:unsubscribe channel [channel]
    作用:退出指定的频道,不订阅。
    返回值:退订的告知消息

    2.2实验步骤(详细代码)

    构建一个发布订阅系统,包括一个消息发布者,两个消息订阅者
    启动Docker中,通过Redis启动redis服务

    请添加图片描述

    请添加图片描述

    请添加图片描述

    使用cmd窗口,连接到redis服务器上
    redis-cli
    
    • 1

    请添加图片描述

    依次开启三个客户端,并记清楚顺序

    请添加图片描述

    发布者设置频道

    自行命名一个频道,让两个消息订阅者订阅该频道,就命名为“bingo”吧!

    publish bingo message
    
    • 1

    请添加图片描述

    订阅者订阅频道
    subscribe Channel(bingo)
    
    • 1

    请添加图片描述

    发布者在频道上发布消息
    publish channel message
    
    • 1

    请添加图片描述

    订阅者自动接收消息

    请添加图片描述
    注意:
    发布的消息没有持久化,发布者只能收到 订阅后发布者发布的消息,意识是订阅前的消息不能收到,取消订阅后发的消息也收不到。

  • 相关阅读:
    STTextBox - 一个纯GDI开发的开源WinForm控件
    巧用CSS3之进击的青豆
    Java SPI
    【C++】了解模板--泛型编程基础
    CF1556B Take Your Places!
    安全监控系统设备、设施管理制度
    ThreadLocal的应用及原理
    LeetCode每日一题:1488. 避免洪水泛滥(2023.10.13 C++)
    Lumiprobe 脱氧核糖核酸丨磷酸盐 CPG 1000 固体载体
    Spring MVC 的核心组件有哪些?
  • 原文地址:https://blog.csdn.net/weixin_51293984/article/details/126880676