一、实验目的

了解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

请添加图片描述

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

请添加图片描述

发布者设置频道

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

publish bingo message

请添加图片描述

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

请添加图片描述

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

请添加图片描述

订阅者自动接收消息

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

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐