一、实验目的
了解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
订阅者自动接收消息
注意: 发布的消息没有持久化,发布者只能收到 订阅后发布者发布的消息,意识是订阅前的消息不能收到,取消订阅后发的消息也收不到。
|