Redis 消息队列的实现

Posted wadhf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis 消息队列的实现相关的知识,希望对你有一定的参考价值。

概述

Redis实现消息队列有两种形式:

  1. 广播订阅模式:基于Redis的 Pub/Sub 机制,一旦有客户端往某个key里面 publish一个消息,所有subscribe的客户端都会触发事件
  2. 集群订阅模式:基于Redis List双向+ 原子性 + BRPOP

Redis消息队列时,当Redis宕机后,消息可能会丢失(也要看持久化的策略)。如果收消息方未有重发和验证机制,Redis内的数据会出现丢失。所以,使用Redis的作为消息队列,通常是对于消息的准确性并非特别高的场景。

原理

  1. 基于Redis的 List的队列性质:从Left插入元素,从Right Pop元素
  2. 原子性:避免并发线程不安全,比如LPush的时候、BRPOP的时候
  3. BRPOP:提升性能,保证及时性又降低无效请求的次数,类似于RocketMQ的长轮询Pull消息。如果不考虑性能的话,也可直接用RPOP命令

以上是关于Redis 消息队列的实现的主要内容,如果未能解决你的问题,请参考以下文章

Redis的基本使用(二) 消息队列

Redis 实现 消息队列

Redis(五)-特性-消息队列

redis怎么做消息队列

使用redis实现消息队列

Redis进阶学习04---秒杀优化和消息队列