Redis 發布訂閱
Redis 發布訂閱(pub/sub)是一種訊息通訊模式:發送者(pub)發送訊息,訂閱者(sub)接收訊息。
Redis 用戶端可以訂閱任意數量的頻道。
下圖展示了頻道 channel1 ,以及訂閱這個頻道的三個客戶端——client2 、 client5 和client1 之間的關係:
當有新訊息通過PUBLISH 命令當傳送給頻道channel1 時, 這個訊息就會被傳送給訂閱它的三個客戶端:
實例
#以下實例示範了發佈訂閱是如何運作的。在我們實例中我們建立了訂閱頻道名為redisChat:
redis 127.0.0.1:6379> SUBSCRIBE redisChat Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "redisChat" 3) (integer) 1
現在,我們先重新開啟個redis 用戶端,然後在同一個頻道redisChat 發布兩次訊息,訂閱者就能接收到訊息。
redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique" (integer) 1 redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by w3cschool.cc" (integer) 1 # 订阅者的客户端会显示如下消息 1) "message" 2) "redisChat" 3) "Redis is a great caching technique" 1) "message" 2) "redisChat" 3) "Learn redis by w3cschool.cc"
Redis 發布訂閱命令
#下表列出了redis 發布訂閱常用命令:
序號 | 指令及描述 |
---|---|
1 | PSUBSCRIBE pattern [pattern ...] 訂閱一個或多個符合給定模式的頻道。 |
2 | PUBSUB subcommand [argument [argument ...]] 查看訂閱與發布系統狀態。 |
3 | PUBLISH channel message 將訊息傳送到指定的頻道。 |
4 | PUNSUBSCRIBE [pattern [pattern ...]] 取消所有給定模式的頻道。 |
5 | SUBSCRIBE channel [channel ...] 訂閱給定的一個或多個頻道的資訊。 |
6 | UNSUBSCRIBE [channel [channel ...]] 指退訂給定的頻道。 |