Redis釋出訂閱

zc發表於2021-07-06

Redis釋出訂閱

什麼是釋出訂閱

所謂釋出訂閱,就是 訊息釋出者釋出訊息訊息訂閱者接收訊息 ,二者通過某種媒介關聯起來。

這類似以前的『訂報』,當我們訂閱了某種報紙後(比如財經報),每當報紙有新的期刊出版後,就會有郵遞員給我們送過來。即,只有定了這種報紙才會收到出版社釋出的這種新報紙。

釋出訂閱解析

Redis釋出訂閱(pub/sub)是一種 訊息通訊模式 :傳送者(pub)傳送訊息,訂閱者(sub)接收訊息。

Redis客戶端可以訂閱任意數量的頻道。

訂閱/釋出訊息圖:

圖中可以看出,所需:

  1. 訊息傳送者 、 2. 頻道 、 3. 訊息訂閱者

1

釋出和訂閱機制

當一個客戶端通過 PUBLISH 命令向訂閱者傳送資訊的時候,我們稱這個客戶端為釋出者(publisher)

而當一個客戶端使用 SUBSCRIBE 或者 PSUBSCRIBE 命令接收資訊的時候,我們稱這個客戶端為 訂閱者(subscriber)

為了解耦 釋出者(publisher) 和 訂閱者(subscriber) 之間的關係,Redis 使用了 channel (頻道) 作為兩者的中介—— 釋出者將資訊直接釋出給 channel ,而 channel 負責將資訊傳送給適當的訂閱者,釋出者和訂閱者之間沒有相互關係,也不知道對方的存在

頻道 channel1 ,以及訂閱這個頻道的三個客戶端----client2client5client1 之間的關係:

2

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

3

Redis 釋出訂閱命令

下表列出了 redis 釋出訂閱常用命令:

4

測試

  • 訂閱端:進行訂閱
  • 傳送端:傳送資訊
  • 檢視是否收到

訂閱端

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

相關文章