Redis的发布与订阅
1、发布与订阅
1.1 什么是发布和订阅
发布订阅模式是一种应用程序(系统)之间通讯、传递数据的技术手段,特别是在异构(不同语言)系统之间作用非常明显,可以实现应用(系统)之间的解耦合。
发布订阅是一对多的关系,需要有信息的发布者和消息的收听者。订阅者:对某个内容感兴趣,需要实时获取新的内容,只要关注的内容有变化就能立即得到通知。发布者:提供某个内容或主题,把内容信息发送给多个对此内容感兴趣的订阅者。
发布订阅应用在即时通信应用中较多,比如网络聊天室,实时广播,实时提醒等。滴滴打车软件的抢单,外卖的抢单,微信中关注公众号/订阅号,公众号/订阅号发布的文章和信息等,也都可以使用发布订阅实现。
1.2 Redis 的发布和订阅
Redis 发布订阅 (pub/sub) 也是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息。Redis 客户端可以订阅任意数量的频道。在一些系统中,Redis可以作为简易的单项消息通信服务器,提供数据群发功能。
2、Redis 发布与订阅的实现
2.1 常用命令
发布与订阅相关命令
(1)publish 发布消息
语法:publish chanel(频道名称) message
作用:将 message 消息发送到 channel 频道。message 是要发送的消息,channel
是自定义的频道名称,唯一标识发布者。
返回值:数值,表示接收到消息订阅者的数量。
(2)subscribe 订阅频道
语法:subscribe channel[channel…]
作用:订阅一个或多个频道的信息 返回值:订阅的消息。
(3)unsubscribe 退订频道
语法:unsubscribe channel [channel]
作用:退出指定的频道,不订阅。
返回值:退订的告知消息。
2.2 例子
(1)构建一个发布订阅系统,包括 1 个消息发布者,2 个消息订阅者。
(2)使用 cmd(命令行)窗口,连接到 redis 服务器上,依次开启 3 个 redis 客户端。
其中 1 个为消息发布者,2 个客户端作为消息订阅者。
(3)订阅者订阅频道
自行命名一个频道,让 2 个消息订阅者订阅该频道。如频道为“myChannel”
命令:subscribe myChannel
(4)发布者在频道上发布消息
消息发布者向频道主题上发布消息:
命令:publish channel message
(5)订阅者自动接收消息
注:发布的消息没有持久化,发布者只能收到订阅后,发布者发布的消息。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)