Redis發布訂閱
Redis發布訂閱
什麼是發布訂閱
所謂發布訂閱,就是 消息發布者發布消息
及 消息訂閱者接收消息
,二者通過某種媒介關聯起來。
這類似以前的『訂報』,當我們訂閱了某種報紙後(比如財經報),每當報紙有新的期刊出版後,就會有郵遞員給我們送過來。即,只有定了這種報紙才會收到出版社發布的這種新報紙。
發布訂閱解析
Redis發布訂閱(pub/sub)是一種 消息通訊模式
:發送者(pub)發送消息,訂閱者(sub)接收消息。
Redis客戶端可以訂閱任意數量的頻道。
訂閱/發布消息圖:
圖中可以看出,所需:
- 消息發送者 、 2. 頻道 、 3. 消息訂閱者
發布和訂閱機制
當一個客戶端通過
PUBLISH
命令向訂閱者發送資訊的時候,我們稱這個客戶端為發布者(publisher)
而當一個客戶端使用
SUBSCRIBE
或者PSUBSCRIBE
命令接收資訊的時候,我們稱這個客戶端為訂閱者(subscriber)
為了解耦 發布者(publisher) 和 訂閱者(subscriber) 之間的關係,Redis 使用了
channel (頻道)
作為兩者的中介—— 發布者將資訊直接發布給 channel ,而 channel 負責將資訊發送給適當的訂閱者,發布者和訂閱者之間沒有相互關係,也不知道對方的存在
頻道 channel1
,以及訂閱這個頻道的三個客戶端—-client2
、client5
和 client1
之間的關係:
當有新消息通過 PUBLISH
命令發送給頻道 channel1
時,這個消息就會被發送給訂閱它的三個客戶端:
Redis 發布訂閱命令
下表列出了 redis 發布訂閱常用命令:
測試
- 訂閱端:進行訂閱
- 發送端:發送資訊
- 查看是否收到
訂閱端
127.0.0.1:6379> SUBSCRIBE MoYu #訂閱MoYu,等待發送方發送資訊
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "MoYu"
3) (integer) 1
發送端
127.0.0.1:6379> PUBLISH MoYu "test" #發送test
(integer) 1
127.0.0.1:6379> PUBLISH MoYu "test1" #發送test1
(integer) 1
因為發送端向被訂閱的頻道發送了資訊,這時候訂閱端立刻會收到資訊
訂閱端
127.0.0.1:6379> SUBSCRIBE MoYu
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "MoYu"
3) (integer) 1
1) "message"
2) "MoYu"
3) "test" #收到的資訊
1) "message"
2) "MoYu"
3) "test1" #收到的資訊
發送訂閱原理
Redis是使用C實現的,通過分析Redis源碼里的pubsub.c文件,了解發布和訂閱機制的底層實現,籍此加深對Redis的理解。
Redis通過PUBLISH,SUBSCRIBE和PSUBSCRIBE等命令實現發布和訂閱功能。
通過SUBSCRIBE命令訂閱某頻道後,redis-server里維護了一個字典,字典的鍵就是一個個channel,而字典的值則是一個鏈表,鏈表中保存了所有訂閱這個channel的客戶端。SUBSCRIBE命令的關鍵,就是將客戶端添加到給定channel的訂閱鏈表中。
通過PUBLISH命令向訂閱者發送消息,redis-server會使用給定的頻道作為鍵,在它所維護的channel字典中查找記錄了訂閱這個頻道的所有客戶端的鏈表,遍歷這個鏈表,將消息發布給所有訂閱者。
Pub/Sub從字面上理解就是發布(Publish)與訂閱(Subscribe),在Redis中,你可以設定對某一個key值進行消息發布及消息訂閱,當一個key值上進行了消息發布後,所有訂閱它的客戶端都會收到相應的消息。這一功能最明顯的用法就是用作實時消息系統,比如普通的即時聊天,群聊等功能。
個人部落格為:
MoYu’s HomePage