【赵渝强老师】Redis消息的生产者消费者模式

在这里插入图片描述
  一般来说消息队列有两种场景,一种是发布者订阅者模式,而另一种是生产者消费者模式。这两种场景的消息队列Redis都能够实现。
  该模式是利用了List能够实现队列(先进先出)和栈(先进后出)的特点。Redis List的主要操作为lpush/lpop/rpush/rpop四种,分别代表从头部和尾部的push/pop,除此之外List还提供了两种pop操作的阻塞版本blpop/brpop,用于阻塞获取一个对象。
  生产者将消息数据添加到List结构中,消费者通过rpop或者brpop消费消息,brpop是阻塞的方式,可以设置等待时长。如果有多个消费者同时监听该列表,只有一个能取到消息。因此这种模式的应用场景主要适用于对于每个消息只能被最多一个消费者所消费的场景。
  视频讲解如下:

Redis消息的生产者消费者模式

【赵渝强老师】Redis消息的生产者消费者模式

  下面的通过具体的步骤来演示如何使用Redis消息机制的生产者消费者模式。

127.0.0.1:6379> lpush myqueue a1
(integer) 1
127.0.0.1:6379> lpush myqueue a2
(integer) 2
127.0.0.1:6379> lpush myqueue a3
(integer) 3
127.0.0.1:6379> lpush myqueue a4
(integer) 4
127.0.0.1:6379> lpop myqueue
"a4"
127.0.0.1:6379> lpop myqueue
"a3"
127.0.0.1:6379> lpop myqueue
"a2"
127.0.0.1:6379> lpop myqueue
"a1"

《Redis架构原理与高性能实战》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵渝强老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值