最近看到一篇文章https://segmentfault.com/a/11… 里面有两句是这样的:
lpush+rpop=Queue(队列)
lpush+brpop=Message Queue(消息队列)
突然不明白redis队列和redis消息队列的异同点?分别适用于什么场景?
我之前有个场景使用到redis队列,分享出来大伙看看用的对不对,是这样的:抢单功能,一个订单只有一个名额,为了防止高并发的情况,我使用redis队列,把抢单的用户id放入队列里面(使用lpush),最后我只取队列的第一个元素(rpop),因为谁抢的快就是谁的。不知道行不行得通?
以上三个疑惑,希望各位求教,谢谢
回答
BRPOP命令和RPOP命令相似,唯一的区别是当列表中没有元素时BRPOP命令会一直阻塞住连接,直到有新元素加入。
另外Redis本就是单线程的,一个订单一个名额的话,你直接放个string不就行了,有这个key则取,无则返回不能下单了(Redis的操作本就是单线程)
消息队列(RabbidMQ, ActiveMQ,Kafka)主要有两种使用模式:生产者->消费者,发布者->订阅者
第一种方式是一对一,后者是一对多
消费掉,队例中数据便不再保存,所谓阅后即焚。消息队列的存和取一般是不同的服务,用于服务之间的异步操作,解耦同步操作。
Redis属于NoSQL类型的缓存/存储,侧重点在支持快速反复读取。数据的产生和消费可能是同一个服务,也可以是多个,如集群。
EDITED:
上面的回答与题主的问题没有太大关系(没有仔细看…), 请不要被误导.