Redis:pub/sub實現消息發佈/訂閱

轉載自http://www.runoob.com/redis/redis-pub-sub.htmlhtml

Redis 發佈訂閱

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

pubsub1

當有新消息經過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被髮送給訂閱它的三個客戶端:htm

pubsub2

實例

如下實例演示了發佈訂閱是如何工做的。在咱們實例中咱們建立了訂閱頻道名爲 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 發佈訂閱命令

下表列出了 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 ...]] 指退訂給定的頻道。
相關文章
相關標籤/搜索