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 @ 2021-07-14 17:47  沧海一声笑rush  阅读(172)  评论(0编辑  收藏  举报