[toc]
## 介紹
Redis 發布訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。主要的目的是解耦消息發布者和消息訂閱者之間的耦合,這點和設計模式中的觀察者模式比較相似。pub /sub不僅僅解決發布者和訂閱者直接代碼級別耦合也解決兩者在物理部署上的耦合。
redis作為一個pub/sub server,在訂閱者和發布者之間起到了消息路由的功能。訂閱者可以通過subscribe和psubscribe命令向redis server訂閱自己感興趣的消息類型,redis將消息類型稱為通道(channel)。當發布者通過publish命令向redis server發送特定類型的消息時。訂閱該消息類型的全部client都會收到此消息。這里消息的傳遞是多對多的。一個client可以訂閱多個channel,也可以向多個channel發送消息。
下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關系:
![pubsub1.png-7kB][1]
當有新消息通過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被發送給訂閱它的三個客戶端:
![pubsub2.png-10.4kB][2]
最明顯的用法就是構建實時消息系統,比如普通的即時聊天,群聊等功能。這時每個人都是訂閱者與發布者。
## 命令簡述
SUBSCRIBE channel [channel2 ...]
訂閱給定的一個或多個頻道的信息。
PSUBSCRIBE pattern [pattern ...]
訂閱一個或多個符合給定模式的頻道。每個模式以 \* 作為匹配符,比如 it\* 匹配所有以 it 開頭的頻道( it.news 、 it.blog 、 it.tweets 等等)。 news.\* 匹配所有以 news. 開頭的頻道( news.it 、 news.global.today 等等),諸如此類。
pubsub channels [pattern]
列出活躍頻道(正在被subscribe監聽的頻道,注意不包括psubscribe監聽的)
pubsub numsub [channel-1 ... channel-n]
返回給定頻道的訂閱者數量,訂閱模式的客戶端不計算在內
PUBSUB NUMPAT
返回訂閱模式的數量。
UNSUBSCRIBE [channel [channel ...]]
指退訂給定的頻道。
PUNSUBSCRIBE [pattern [pattern ...]]
退訂所有給定模式的頻道。
PUBLISH channel message
將信息發送到指定的頻道。
## Example
開兩個redis-cli 一個作為發布者,一個作為訂閱者;
```
# 訂閱者
127.0.0.1:6379> subscribe news #訂閱news頻道,這個時候就是一個監聽狀態了,只要發布者一發布消息,訂閱者就會收到
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "news"
3) (integer) 1
# 發布者
redis 127.0.0.1:6379> publish news 'good good study'
(integer) 1 #這里反饋的是有多少個subscribe客戶端接收到這條news;
redis 127.0.0.1:6379> publish news 'day day up'
(integer) 1
```
[1]: http://static.zybuluo.com/a5635268/i2zuhl05irqs1z484jv6p3x1/pubsub1.png
[2]: http://static.zybuluo.com/a5635268/yh4pwgrgamvtc9ootae3s72c/pubsub2.png