1. 程式人生 > 其它 >Redis 14 釋出訂閱

Redis 14 釋出訂閱

參考源

https://www.bilibili.com/video/BV1S54y1R7SB?spm_id_from=333.999.0.0

版本

本文章基於 Redis 6.2.6

概述

Redis 釋出訂閱(pub / sub)是一種訊息通訊模式

傳送者(pub)傳送訊息,訂閱者(sub)接收訊息。

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

訂閱/釋出訊息圖:

頻道和訂閱頻道的客戶端之間的關係:

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

命令

這些命令被廣泛用於構建即時通訊應用,比如網路聊天室(chat room)和實時廣播、實時提醒等。

實踐

以下例項演示了釋出訂閱是如何工作的。

在我們例項中我們建立了訂閱頻道名為 redisChat

視窗 1,訂閱頻道:

127.0.0.1:6379> subscribe redisChat
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1

視窗 2,訂閱頻道:

127.0.0.1:6379> subscribe redisChat
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1

視窗 3,頻道釋出訊息:

127.0.0.1:6379> publish redisChat "Hello,Redis"
(integer) 2
127.0.0.1:6379> publish redisChat "Hello,World"
(integer) 2

視窗 1 和視窗 2 都會收到釋出的訊息:

1) "message"
2) "redisChat"
3) "Hello,Redis"
1) "message"
2) "redisChat"
3) "Hello,World"

原理

  • Redis 是使用 C 實現的,通過分析 Redis 原始碼裡的 pubsub.c 檔案,可以瞭解釋出和訂閱機制的底層實現。

  • Redis 通過 publish 、subscribe 和 psubscribe 等命令實現釋出和訂閱功能。

  • 通過 subscribe 命令訂閱某頻道後,redis-server 裡維護了一個字典,字典的鍵就是一個個 channel。

  • 而字典的值則是一個連結串列,連結串列中儲存了所有訂閱這個 channel 的客戶端。

  • subscribe 命令的關鍵,就是將客戶端新增到給定 channel 的訂閱連結串列中。

  • 通過 publish 命令向訂閱者傳送訊息,redis-server 會使用給定的頻道作為鍵,在它所維護的 channel 字典中查詢記錄了訂閱這個頻道的所有客戶端的連結串列,遍歷這個連結串列,將訊息釋出給所有訂閱者。

  • pub / sub 從字面上理解就是釋出(Publish)與訂閱(Subscribe),在 Redis 中,你可以設定對某一個 key 值進行訊息釋出及訊息訂閱,當一個 key 值上進行了訊息釋出後,所有訂閱它的客戶端都會收到相應的訊息。

  • 這一功能最明顯的用法就是用作實時訊息系統,比如普通的即時聊天,群聊等功能。