是什么
是一种消息通信模式:发送者(PUBLISH)发送消息,订阅者(SUBSCRIBE)接收消息,可以实现进程间的消息传递。
Redis可以实现中间件的MQ功能,通过发布订阅实现消息的引导和分流。
能干嘛
Redis客户端可以订阅任意数量的频道,类似我们微信关注多个公众号。
当有新消息通过PUBLISH命令发送给频道channel1时
概括
发布/订阅其实是一个轻量的队列,只不过数据不会被持久化,一般用来处理 实时性较高的异步消息。
常用命令
SUBSCRIBE channel [channel…]:订阅给定的一个或多个频道的信息
推荐先执行订阅后再发布,订阅成功之前发布的消息是收不到的。
订阅的客户端每次可以收到一个3个参数的消息。
-
消息的种类
-
始发频道的名称
-
消息内容
PUBLISH channel message
:发布消息到指定的频道
PSUBSCRIBE pattern [pattern...]
:按照模式批量订阅,订阅一个或多个符合给定模式(支持*号?号之类的)的频道
PUBSUB subcommand[argument[argument...]]
:查看订阅与发布系统状态
-
PUBSUB CHANNELS
由活跃频道组成的列表 -
PUBSUB NUMSUB [channel[channel...]]
:某个频道有几个订阅者 -
PUBSUB NUMPAT
:只统计使用PSUBSCRIBE命令执行的,返回客户端订阅的唯一模式数量
UNSUBSCRIBE [channel[channel...]]
:取消订阅
PUNSUBSCRIBE [pattern[pattern]]
:退订所有给定模式的频道
总结
-
Redis可以实现消息中间件MQ的功能,通过发布订阅实现消息的引导和分流。
-
Pub/Sub缺点:
-
发布的消息在Redis系统中不能持久化,因此,必须先执行订阅,再等待消息发布。如果先发布了消息,那么该消息由于没有订阅者,消息将直接丢弃
-
消息只管发送对于发布者而言是即发即失的,不管接收,且没有ACK机制,无法保证消息消费成功。
-
以上缺点导致Redis的Pub/Sub模式就像个小玩具,在生产环境中几乎无用武之地,为此Redis5.0版本新增了Stream数据结构,不但支持多播,还支持数据持久化,相比Pub/Sub更加的强大。
-
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容