Redis釋出訂閱
Redis釋出訂閱
Redis 釋出訂閱(pub/sub)是一種訊息通訊模式:傳送者(pub)傳送訊息,訂閱者(sub)接收訊息。微信、 微博、關注系統!
Redis 客戶端可以訂閱任意數量的頻道。
訂閱/釋出訊息圖:
第一個:訊息傳送者, 第二個:頻道 第三個:訊息訂閱者!
下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的 關係:
當有新訊息通過 PUBLISH 命令傳送給頻道 channel1 時, 這個訊息就會被髮送給訂閱它的三個客戶 端:
命令
這些命令被廣泛用於構建即時通訊應用,比如網路聊天室(chatroom)和實時廣播、實時提醒等。
測試
訂閱端:
127.0.0.1:6379> SUBSCRIBE kuangshenshuo # 訂閱一個頻道 kuangshenshuo Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "kuangshenshuo" 3) (integer) 1 # 等待讀取推送的資訊 1) "message" # 訊息 2) "kuangshenshuo" # 那個頻道的訊息 3) "hello,kuangshen" # 訊息的具體內容 1) "message" 2) "kuangshenshuo" 3) "hello,redis"
傳送端:
127.0.0.1:6379> PUBLISH kuangshenshuo "hello,kuangshen" # 釋出者釋出訊息到頻道!
(integer) 1
127.0.0.1:6379> PUBLISH kuangshenshuo "hello,redis" # 釋出者釋出訊息到頻道!
(integer) 1
127.0.0.1:6379>
原理
Redis是使用C實現的,通過分析 Redis 原始碼裡的 pubsub.c 檔案,瞭解釋出和訂閱機制的底層實現,籍 此加深對 Redis 的理解
Redis 通過 PUBLISH 、SUBSCRIBE 和 PSUBSCRIBE 等命令實現釋出和訂閱功能。
微信: 通過 SUBSCRIBE 命令訂閱某頻道後,redis-server 裡維護了一個字典,字典的鍵就是一個個 頻道!, 而字典的值則是一個連結串列,連結串列中儲存了所有訂閱這個 channel 的客戶端。SUBSCRIBE 命令的關鍵, 就是將客戶端新增到給定 channel 的訂閱連結串列中。
通過 PUBLISH 命令向訂閱者傳送訊息,redis-server 會使用給定的頻道作為鍵,在它所維護的 channel 字典中查詢記錄了訂閱這個頻道的所有客戶端的連結串列,遍歷這個連結串列,將訊息釋出給所有訂閱者。
Pub/Sub 從字面上理解就是釋出(Publish)與訂閱(Subscribe),在Redis中,你可以設定對某一個 key值進行訊息釋出及訊息訂閱,當一個key值上進行了訊息釋出後,所有訂閱它的客戶端都會收到相應 的訊息。這一功能最明顯的用法就是用作實時訊息系統,比如普通的即時聊天,群聊等功能。
使用場景:
- 實時訊息系統!
- 實時聊天!(頻道當做聊天室,將資訊回顯給所有人即可!)
- 訂閱,關注系統都是可以的! 稍微複雜的場景我們就會使用 訊息中介軟體 MQ ()