Redis(五)发布与订阅


1、什么是发布与订阅

Redis 发布订阅 (pub/sub) 是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息。
Redis 的 subscribe 命令可以让客户端订阅任意数量的频道, 
每当有新信息发送到被订阅的频道时, 信息就会被发送给所有订阅指定频道的客户端。

在这里插入图片描述
三个「订阅者」订阅「Channel1」频道:

在这里插入图片描述
当 Channel1 的后台发送了一个数据到 Channel1 的频道中,这三个订阅了 Channel1 的客户端就会同时收到这个数据:
在这里插入图片描述

2、指令与描述

命令描述
PSUBSCRIBE pattern [pattern …]订阅一个或多个符合给定模式的频道
PUBSUB subcommand [argument [argument …]]查看订阅与发布系统状态
PUBLISH channel message将信息发送到指定的频道
PUNSUBSCRIBE [pattern [pattern …]]退订所有给定模式的频道
SUBSCRIBE channel [channel …]订阅给定的一个或多个频道的信息
UNSUBSCRIBE [channel [channel …]]退订给定的频道,说明:若没有指定channel,则默认退订所有频道

3、指令测试

在这里插入图片描述
查看活跃的频道
在这里插入图片描述
通过 SUBSCRIBE 命令订阅某频道后,redis-server 里维护了一个字典,字典的键就是一个个 channel ,而字典的值则是一个链表,链表中保存了所有订阅这个 channel 的客户端。SUBSCRIBE 命令的关键,就是将客户端添加到给定 channel 的订阅链表中。
在这里插入图片描述客户端订阅,就被链接到对应频道的链表的尾部,退订则就是将客户端节点从链表中移除。
缺点:

  • 客户端订阅了channel之后,如果接收消息不及时,可能导致消息堆积,当达到消息堆积阈值(默认值为32MB),或者达到某种程度(默认8MB)一段时间(默认为1分钟)后,服务器端会自动断开该客户端连接,避免导致内部内存耗尽。
  • 当连接断开之后,客户端需要使用subscribe或者psubscribe重新进行订阅,否则无法继续接收消息
  • Redis的pubsub不是一种可靠的消息系统。当出现客户端连接退出,或者极端情况下服务端发生主备切换时,未消费的消息会被丢弃

应用场景:

1、实时沟通消息系统
2、个人博客系统(粉丝关注博主,博主发送一篇博客,订阅的用户就可以监听到)
3、电商中,用户下单成功之后向指定频道发送消息,下游业务订阅支付结果这个频道处理自己相关业务逻辑
Redis的pubsub不是一种可靠的消息系统。如果场景复杂,可以使用消息中间件来做,kafka RabbitMQ ActiveMQ RocketMQ …等

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Redis发布订阅(Pub/Sub)功能是一种消息传递模式,允许多个客户端订阅频道以接收消息,并且可以将消息发布到指定的频道中。 下面是使用Redis发布订阅功能的基本步骤: 1. 订阅频道:使用SUBSCRIBE命令可以订阅一个或多个频道。例如,要订阅名为"channel1"和"channel2"的频道,可以执行以下命令: ``` SUBSCRIBE channel1 channel2 ``` 2. 发布消息:使用PUBLISH命令可以将消息发布到指定的频道。例如,要将消息"Hello, Redis Pub/Sub!"发布到名为"channel1"的频道中,可以执行以下命令: ``` PUBLISH channel1 "Hello, Redis Pub/Sub!" ``` 3. 接收消息:订阅频道后,Redis将会推送所有发布到该频道的消息。你可以通过订阅命令的响应来接收消息。例如,如果有消息发布到了"channel1"频道,你将收到以下响应: ``` message channel1 "Hello, Redis Pub/Sub!" ``` 4. 取消订阅:当你不再需要接收某个频道的消息时,可以使用UNSUBSCRIBE命令取消对该频道的订阅。例如,要取消对"channel1"频道的订阅,可以执行以下命令: ``` UNSUBSCRIBE channel1 ``` 使用Redis发布订阅功能,可以实现解耦和异步通信,适用于实时消息推送、事件驱动的架构等场景。请注意,Redis发布订阅功能是单向的,无法保证消息的可靠性传递。如果需要更高级别的消息队列功能,可以考虑使用Redis Streams或其他消息队列系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贫僧洗发爱飘柔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值