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 # 等待数据
可以同时开两个窗口实验一下
实现优先级队列
比如我们现在有两个队列,一个队列是用来转账的,一个队列是用来收账的,那么从优先级上来看,肯定是收账的优先级更高。那么如何区分队列的优先级呢?
我们可以借助于于 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
Redis发布者和订阅者模式
除了使用 list
来实现发布者和订阅者这种模式以外,还可以使用专门的工具,来实现发布者定语者模式。
publish chan01 aabb #发布消息,指定通道
subscribe chan01 #订阅者,指定从哪个通道接受
效果如下
区别
redis 有自带的发布者订阅者模式。和使用队列不同的点,笔者以为主要有以下两点
- 发布者的返回结果是个数,表示有多少个客户端接受到了消息
- 订阅者只能接受从订阅时刻开始后的信息,之前的收不到
- 订阅者除了能看到收到的消息,还能看到是从哪里收到的