Redis 订阅者发布者模式

简单实现

实现消息队列,只需要发布者在 list 中,使用lpush 往队列里添加值,订阅者在另一侧,使用 RPOP , 从队列中往外取值。

复制lpush list01 1 2 3 4 5 6   #往队列里面添加值
rpop  list01               #从队列里面取值

存在的问题

上面就是一个简单的消息队列,但是存在一个很大的问题。每次都要使用 rpop 去取 list 中的东西,或者是编写程序每过一秒钟读取一次。

为解决上述问题,我们使用 Brpop 取代 rpop,唯一的区别是, Brpop当时数组内没有命令的时候,会出现阻塞。直到有元素加入为止

lpush list02 6 # 插入数据
brpop list02 8 # 等待数据

可以同时开两个窗口实验一下

image

实现优先级队列

比如我们现在有两个队列,一个队列是用来转账的,一个队列是用来收账的,那么从优先级上来看,肯定是收账的优先级更高。那么如何区分队列的优先级呢?

我们可以借助于于 brpop命令可以从两个队列中取值的特性实现,它会优先从list01里取,然后再从list02里取

lpush list01 1 2 3 4 5 6  #在list01中插入数据
lpush list02 7 8 9 10 11  #在list01中插入数据

# 使用brpop 从多个队列中取值
brpop list01 list02 5 #最后的5是等待时间

# 输出结果
1 2 3 4 5 6 7 8 9 10 11

image

Redis发布者和订阅者模式

除了使用 list来实现发布者和订阅者这种模式以外,还可以使用专门的工具,来实现发布者定语者模式。

publish chan01 aabb #发布消息,指定通道

subscribe chan01    #订阅者,指定从哪个通道接受

效果如下

image

区别

redis 有自带的发布者订阅者模式。和使用队列不同的点,笔者以为主要有以下两点

  1. 发布者的返回结果是个数,表示有多少个客户端接受到了消息
  2. 订阅者只能接受从订阅时刻开始后的信息,之前的收不到
  3. 订阅者除了能看到收到的消息,还能看到是从哪里收到的
posted @   沧海一声笑rush  阅读(174)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示