Redis的发布与订阅

Redis有两种发布/订阅模式:

  • 基于频道(Channel)的发布/订阅

  • 基于模式(pattern)的发布/订阅

序号命令与描述
1subscribe channel [channel ... ] 订阅给定的一个或多个频道
2unsubscribe channel [channel ... ] 退订给定的频道 说明:若没有指定channel,则默认退订所有频道
3publish channel message 将消息发送给指定频道 channel 返回结果:接收到信息的订阅者数量,无订阅者返回0
4pubsub channels [argument [atgument ...] ] 查看订阅与发布系统的状态 说明:返回活跃频道列表(即至少有一个订阅者的频道,订阅模式的客户端除外)
5psubscribe pattern1 [pattern...] 订阅一个或多个符合给定模式的频道 说明:每个模式以 * 作为匹配符;例如 shujia* 匹配所有以shujia开头的频道:shujia.java、shujia.hadoop
6punsubscribe [pattern [pattern ...] ] 退订所有给定模式的频道 说明:pattern 未指定,则订阅的所有模式都会被退订,否则只退订指定的订阅的模式

说到发布订阅就不得不提前说到消息队列了

redis中的List数据类型其实可以将数据进行排队,然后按照顺序取出,但是没法精确获取(俗称 双端队列)

这种方式存在两个局限性:双端队列模式只能有一个或多个消费者轮着去消费,却不能将消息同时发给其他消费者

  • 不能支持一对多的消息分发。

  • 如果生产者生成的速度远远大于消费者消费的速度,易堆积大量未消费的消息

画图理解:

redis中的发布订阅模式,是一种消息传递模式,可用于实现多个客户端之间的实时消息通信。在这种模式下,消息发送者称为发布者,而接收消息的客户端称为订阅者。

角色:

发布者(Publisher)

  • 使用 PUBLISH 命令将消息发布到指定的频道。

订阅者(Subscriber)

  • 使用 SUBSCRIBE 命令订阅一个或多个频道以接收消息。所有订阅同一频道的订阅者都会收到此消息。

频道(Channel)

  • 频道是消息的通道,发布者通过指定频道来发布消息,订阅者通过订阅频道来接收相关消息。

消息(Message)

  • 消息是由发布者发送给订阅者的数据。                                                                                       

 发送端

接受端

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值