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 …]] | 指退訂給定的頻道。 |