Redis 發布訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。
Redis 客戶端可以訂閱任意數量的頻道。
下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關系:
Paste_Image.png
當有新消息通過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被發送給訂閱它的三個客戶端:
Paste_Image.png
實例
以下實例演示了發布訂閱是如何工作的。在我們實例中我們創建了訂閱頻道名為 redisChat:
Paste_Image.png
現在,我們先重新開啟個 redis 客戶端,然后在同一個頻道 redisChat 發布兩次消息,訂閱者就能接收到消息。
Paste_Image.png
訂閱者的客戶端會顯示如下消息
Paste_Image.png
Redis 發布訂閱命令
下表列出了 redis 發布訂閱常用命令:
1 Psubscribe
Redis Psubscribe 命令訂閱一個或多個符合給定模式的頻道。
每個模式以 * 作為匹配符,比如 it* 匹配所有以 it 開頭的頻道( it.news 、 it.blog 、 it.tweets 等等)。 news.* 匹配所有以 news. 開頭的頻道( news.it 、 news.global.today 等等),諸如此類。
# 語法
redis 127.0.0.1:6379> PSUBSCRIBE pattern [pattern ...]
# 返回值
接收到的信息。
# 實例
redis 127.0.0.1:6379> PSUBSCRIBE mychannel
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "mychannel"
3) (integer) 1
2 Pubsub
Redis Pubsub 命令用于查看訂閱與發布系統狀態,它由數個不同格式的子命令組成。
# 語法
redis 127.0.0.1:6379> PUBSUB <subcommand> [argument [argument ...]]
# 返回值
由活躍頻道組成的列表。
# 實例
127.0.0.1:6379> PUBSUB redisChat
(error) ERR Unknown PUBSUB subcommand or wrong number of arguments for 'redisChat'
127.0.0.1:6379> PUBSUB channels
1) "redisChat"
3 Publish
Redis Publish 命令用于將信息發送到指定的頻道。
# 語法
redis 127.0.0.1:6379> PUBLISH channel message
# 返回值
接收到信息的訂閱者數量。
# 實例
127.0.0.1:6379> publish redisChat "kenny2B"
(integer) 1
127.0.0.1:6379> publish redisChat "CTO--SB"
(integer) 1
4 Punsubscribe
Redis Punsubscribe 命令用于退訂所有給定模式的頻道。
# 語法
redis 127.0.0.1:6379> PUNSUBSCRIBE [pattern [pattern ...]]
# 返回值
這個命令在不同的客戶端中有不同的表現。
# 實例
127.0.0.1:6379> PUNSUBSCRIBE redisChat
1) "punsubscribe"
2) "redisChat"
3) (integer) 0
5 Subscribe
Redis Subscribe 命令用于訂閱給定的一個或多個頻道的信息。。
# 語法
redis 127.0.0.1:6379> SUBSCRIBE channel [channel ...]
# 返回值
接收到的信息
# 實例
127.0.0.1:6379> SUBSCRIBE redisChat
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1
1) "message"
2) "redisChat"
3) "kenny2B"
1) "message"
2) "redisChat"
3) "CTO--SB"
6 Unsubscribe
Redis Unsubscribe 命令用于退訂給定的一個或多個頻道的信息。
# 語法
redis 127.0.0.1:6379> UNSUBSCRIBE channel [channel ...]
# 返回值
這個命令在不同的客戶端中有不同的表現。
# 實例
127.0.0.1:6379> UNSUBSCRIBE redisChat
1) "unsubscribe"
2) "redisChat"
3) (integer) 0