Redis的队列和消息队列的区别是什么?

最近看到一篇文章https://segmentfault.com/a/11... 里面有两句是这样的:

lpush+rpop=Queue(队列)
lpush+brpop=Message Queue(消息队列)

突然不明白redis队列和redis消息队列的异同点?分别适用于什么场景?
我之前有个场景使用到redis队列,分享出来大伙看看用的对不对,是这样的:抢单功能,一个订单只有一个名额,为了防止高并发的情况,我使用redis队列,把抢单的用户id放入队列里面(使用lpush),最后我只取队列的第一个元素(rpop),因为谁抢的快就是谁的。不知道行不行得通?

以上三个疑惑,希望各位求教,谢谢

阅读 6.2k
2 个回答

BRPOP命令和RPOP命令相似,唯一的区别是当列表中没有元素时BRPOP命令会一直阻塞住连接,直到有新元素加入。
另外Redis本就是单线程的,一个订单一个名额的话,你直接放个string不就行了,有这个key则取,无则返回不能下单了(Redis的操作本就是单线程)

消息队列(RabbidMQ, ActiveMQ,Kafka)主要有两种使用模式:生产者->消费者,发布者->订阅者
第一种方式是一对一,后者是一对多
消费掉,队例中数据便不再保存,所谓阅后即焚。消息队列的存和取一般是不同的服务,用于服务之间的异步操作,解耦同步操作。

Redis属于NoSQL类型的缓存/存储,侧重点在支持快速反复读取。数据的产生和消费可能是同一个服务,也可以是多个,如集群。

EDITED:

上面的回答与题主的问题没有太大关系(没有仔细看...), 请不要被误导.

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏