消息队列的其他实现方式
生活随笔
收集整理的這篇文章主要介紹了
消息队列的其他实现方式
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
在 Redis 5.0 之前消息隊列的實現(xiàn)方式有很多種,比較常見的除了我們上文介紹的發(fā)布訂閱模式,還有兩種:List 和 ZSet 的實現(xiàn)方式。
List 和 ZSet 的方式解決了發(fā)布訂閱模式不能持久化的問題,但這兩種方式也有自己的缺點,接下來我們一起來了解一下,先從 List 實現(xiàn)消息隊列的方式說起。
List 版消息隊列
List 方式是實現(xiàn)消息隊列最簡單和最直接的方式,它主要是通過 lpush 和 rpop 存入和讀取實現(xiàn)消息隊列的,如下圖所示:
List 使用命令的方式實現(xiàn)消息隊列:
127.0.0.1:6379> lpush mq "hello" #推送消息 hello (integer) 1 127.0.0.1:6379> lpush mq "msg" #推送消息 msg (integer) 2 127.0.0.1:6379> rpop mq #接收到消息 hello "hello" 127.0.0.1:6379> rpop mq #接收到消息 msg "mq"其中,mq 就相當(dāng)于頻道名稱 channel,而 lpush 用于生產(chǎn)消息, rpop 拉取消息。
代碼實現(xiàn)
接下來我們用 Java 代碼的方式來實現(xiàn) List 形式的消息隊列,源碼如下:
import redis.clients.jedis.Jedis;public class ListMQExample {public static void總結(jié)
以上是生活随笔為你收集整理的消息队列的其他实现方式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis 键值过期操作
- 下一篇: 秋招注意事项和面试通关攻略