Redis发布订阅
是什么是一种消息通信模式:发送者(PUBLISH)发送消息,订阅者(SUBSCRIBE)接收消息,可以实现进程间的消息传递。
Redis可以实现中间件的MQ功能,通过发布订阅实现消息的引导和分流。
能干嘛
Redis客户端可以订阅任意数量的频道,类似我们微信关注多个公众号。
https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232305314-1378867676.png
当有新消息通过PUBLISH命令发送给频道channel1时
https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232304804-450842553.png
概括
发布/订阅其实是一个轻量的队列,只不过数据不会被持久化,一般用来处理 实时性较高的异步消息。
https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232304435-1547533982.png
常用命令
SUBSCRIBE channel :订阅给定的一个或多个频道的信息
推荐先执行订阅后再发布,订阅成功之前发布的消息是收不到的。
订阅的客户端每次可以收到一个3个参数的消息。
https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232304064-1475086497.png
[*]消息的种类
[*]始发频道的名称
[*]消息内容
PUBLISH channel message :发布消息到指定的频道
PSUBSCRIBE pattern :按照模式批量订阅,订阅一个或多个符合给定模式(支持*号?号之类的)的频道
PUBSUB subcommand]:查看订阅与发布系统状态
[*]PUBSUB CHANNELS 由活跃频道组成的列表 https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232303759-498054211.png
[*]PUBSUB NUMSUB ]:某个频道有几个订阅者 https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232303445-1218004367.png
[*]PUBSUB NUMPAT:只统计使用PSUBSCRIBE命令执行的,返回客户端订阅的唯一模式数量
https://img2023.cnblogs.com/blog/2328707/202312/2328707-20231206232302971-557747574.png
UNSUBSCRIBE ]:取消订阅
PUNSUBSCRIBE ]:退订所有给定模式的频道
总结
[*]Redis可以实现消息中间件MQ的功能,通过发布订阅实现消息的引导和分流。
[*]Pub/Sub缺点:
[*]发布的消息在Redis系统中不能持久化,因此,必须先执行订阅,再等待消息发布。如果先发布了消息,那么该消息由于没有订阅者,消息将直接丢弃
[*]消息只管发送对于发布者而言是即发即失的,不管接收,且没有ACK机制,无法保证消息消费成功。
[*]以上缺点导致Redis的Pub/Sub模式就像个小玩具,在生产环境中几乎无用武之地,为此Redis5.0版本新增了Stream数据结构,不但支持多播,还支持数据持久化,相比Pub/Sub更加的强大。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
页:
[1]