Redish訂閱與發佈機制

Redis 發佈訂閱

Redis 發佈訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。

Redis 客戶端可以訂閱任意數量的頻道。

下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關係:
在這裏插入圖片描述
當有新消息通過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被髮送給訂閱它的三個客戶端:
在這裏插入圖片描述

案例

接下來我們來演示一下Redis的訂閱與發佈機制是如何工作的
首先打開一個redis客戶端,作爲消息訂閱者訂閱一個通道

127.0.0.1:6379> subscribe channel1
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel"
3) (integer) 1

然後再打開一個tab,同樣開啓一個redis客戶端作爲消息發佈者。通過channel發佈一條消息

127.0.0.1:6379> publish channel "java"
(integer) 1

然後消息訂閱者的窗口將輸出發佈的信息

127.0.0.1:6379> subscribe channel
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel"
3) (integer) 1
1) "message"
2) "channel"
3) "java"
命令 作用
PSUBSCRIBE pattern [pattern …] 訂閱一個或多個符合給定模式的頻道。
PUBSUB subcommand [argument [argument …]] 查看訂閱與發佈系統狀態。
PUBLISH channel message 將信息發送到指定的頻道。
PUNSUBSCRIBE [pattern [pattern …]] 退訂所有給定模式的頻道。
SUBSCRIBE channel [channel …] 訂閱給定的一個或多個頻道的信息。
UNSUBSCRIBE [channel [channel …]] 指退訂給定的頻道。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章