1、是什么
是一种通信模式:发送者(publish)发送消息,订阅者(subscribe)接收消息,可以实现进程间的消息传递
redis可以实现消息中间件mq的功能,通过发布订阅实现消息的引导和分流
2、能干啥
redis客户端可以订阅任意数量的频道,类似于微信关注多个公众号
当有新消息通过publish命令发送给频道channel时
3、常用命令
3.1、subscribe channel [channel.。.]
订阅给定的一个或多个频道的信息
推荐先执行订阅后再发布,订阅成功之前发布的消息是收不到的
订阅的客户端每次可以收到3个参数的消息
消息的种类
始发频道的名称
实际的消息内容
3.2、publish channel message
发布消息到指定的频道
3.3、psubscribe pattern [pattern.。.]
按照模式批量订阅,订阅一个或多个符合给定模式(支持*号?号之类的)频道
3.4、pubsub subcommand [argument [argument.。.]]
查看订阅与发布系统状态
pubsub channels
由活跃频道组成的列表
pubsub numsub channel [channel.。.]
某个频道有几个订阅者
pubsub numpat
只统计使用psubscribe命令执行的,返回客户端订阅的唯一模式的数量
3.5、unsubscribe channel [channel.。.]
取消订阅
3.6、punsubscribe pattern [pattern.。.]
退订所有给定模式的频道
4、案例演示
开启3个客户端,演示客户端a、b订阅消息,客户端c发布消息
演示批量订阅和发布
取消订阅
5、小总结
redis可以实现消息中间件mq的功能,通过发布订阅实现消息的引导和分流
pub/sub缺点
发布的消息在redis系统中不能持久化,因此,必须先执行订阅,再等待消息发布,如果先发布了消息,那么该消息由于没有订阅者,消息将被直接丢弃
消息只管发送,对于发布者而言消息是即发即失的,不管接收,也没有ack机制,无法保证消息的消费成功
以上的缺点导致redis的pub/sub模式就像一个小玩具,在生产环境中几乎无用武之地,为此,redis5.0版本新增了stream数据结构,不但支持多播,还支持数据持久化,相比pub/sub更加的强大
变压器过励磁
超140家零售商与科技公司联手改善AR/VR购物体验
机器视觉知识要点
百度推出小度电视伴侣 朝着家居控制中心的战略前行
虹科新闻 |2022元宇宙荣誉榜创新硬件榜单新鲜出炉,虹科榜上有名
Redis可以实现消息中间件MQ的功能
是德科技推出新的800G测试解决方案
关于移动AR产品的应用场景与方案及开发设计
霍尔效应传感器DRV5000系列的特性与优势介绍
win10隐藏的实用功能介绍与xbox登录失败解决方法
NTP服务器配置概述
组合式变压器的优缺点
哪款蓝牙耳机性价比高?性价比高的真无线蓝牙耳机推荐
一文看懂非晶磁环电感和铁氧体磁环电感的区别
空调外机如何清洗
肖特基二极管为什么三个引脚 三端型肖特基二极管接法
采用P87LPC767单片机实现智能型剩余电流保护器的应用方案
海为PLC在面袋对缝机上的应用
CAN总线怎么实现波特率的设置
洲明一体化解决方案让厚重的人文历史变得喜闻乐见