轉載自http://www.runoob.com/redis/redis-pub-sub.htmlhtml
Redis 的 Pub/Sub 能夠用來實現簡單的訂閱機制。一個或多個 client 向 Redis 訂閱特定的頻道,當某個 client 向這個頻道發佈消息時,Redis 會把消息發送給訂閱該頻道的 client。須要注意的是,Redis 只負責轉發消息,並不保證訂閱的 client 是否真正收到了消息,好比 client 可能正好掛掉了或者中間出了點網絡問題。在某些狀況下,這種簡單的訂閱機制就夠用了;但在某些狀況下,咱們須要確保消息已經發布出去,PubSub 就不能知足要求 。針對這種狀況,市面上有很多專業消息中間件能夠選擇,好比kafaka、rabbitmq、activemq等redis
Redis 發佈訂閱(pub/sub)是一種消息通訊模式:發送者(pub)發送消息,訂閱者(sub)接收消息。網絡
Redis 客戶端能夠訂閱任意數量的頻道。ui
下圖展現了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關係:spa
當有新消息經過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被髮送給訂閱它的三個客戶端:htm
如下實例演示了發佈訂閱是如何工做的。在咱們實例中咱們建立了訂閱頻道名爲 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 發佈兩次消息,訂閱者就能接收到消息。rabbitmq
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 runoob.com" (integer) 1 # 訂閱者的客戶端會顯示以下消息 1) "message" 2) "redisChat" 3) "Redis is a great caching technique" 1) "message" 2) "redisChat" 3) "Learn redis by runoob.com"
下表列出了 redis 發佈訂閱經常使用命令:get
序號 | 命令及描述 |
---|---|
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 ...]] 指退訂給定的頻道。 |