Redis發(fā)布訂閱
概念
Redis 發(fā)布訂閱(pub/sub)是一種消息通信模式:發(fā)送者(pub)發(fā)送消息,訂閱者(sub)接收消息。
Redis 客戶端可以訂閱任意數(shù)量的頻道。
訂閱/發(fā)布消息圖:

下圖展示了頻道 channel1 , 以及訂閱這個(gè)頻道的三個(gè)客戶端 —— client2 、 client5 和 client1 之間的關(guān)系:

當(dāng)有新消息通過(guò) PUBLISH 命令發(fā)送給頻道 channel1 時(shí), 這個(gè)消息就會(huì)被發(fā)送給訂閱它的三個(gè)客戶端:

命令
這些命令被廣泛用于構(gòu)建即時(shí)通信應(yīng)用,比如網(wǎng)絡(luò)聊天室(chatroom)和實(shí)時(shí)廣播、實(shí)時(shí)提醒等。
命令如下:
PSUBSCRIBE pattern [pattern ...] #訂閱一個(gè)或多個(gè)符合給定模式的頻道。
PUBSUB subcommand [argument [argument ...]] #查看訂閱與發(fā)布系統(tǒng)狀態(tài)。
PUBLISH channel message #將信息發(fā)送到指定的頻道。
PUNSUBSCRIBE [pattern [pattern ...]] #退訂所有給定模式的頻道。
SUBSCRIBE channel [channel ...] #訂閱給定的一個(gè)或多個(gè)頻道的信息。
UNSUBSCRIBE [channel [channel ...]] #指退訂給定的頻道。
測(cè)試
以下實(shí)例演示了發(fā)布訂閱是如何工作的。在我們實(shí)例中我們創(chuàng)建了訂閱頻道名為 redisChat:
redis 127.0.0.1:6379> SUBSCRIBE redisChat
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1
現(xiàn)在,我們先重新開啟個(gè) redis 客戶端,然后在同一個(gè)頻道 redisChat 發(fā)布兩次消息,訂閱者就能接收到消息。
redis 127.0.0.1:6379> PUBLISH redisChat "Hello,Redis"
(integer) 1
redis 127.0.0.1:6379> PUBLISH redisChat "Hello,Kuangshen"
(integer) 1
# 訂閱者的客戶端會(huì)顯示如下消息
1) "message"
2) "redisChat"
3) "Hello,Redis"
1) "message"
2) "redisChat"
3) "Hello,Kuangshen"
原理
Redis是使用C實(shí)現(xiàn)的,通過(guò)分析 Redis 源碼里的 pubsub.c 文件,了解發(fā)布和訂閱機(jī)制的底層實(shí)現(xiàn),籍此加深對(duì) Redis 的理解。
Redis 通過(guò) PUBLISH 、SUBSCRIBE 和 PSUBSCRIBE 等命令實(shí)現(xiàn)發(fā)布和訂閱功能。
通過(guò) SUBSCRIBE 命令訂閱某頻道后,redis-server 里維護(hù)了一個(gè)字典,字典的鍵就是一個(gè)個(gè) channel,而字典的值則是一個(gè)鏈表,鏈表中保存了所有訂閱這個(gè) channel 的客戶端。SUBSCRIBE 命令的關(guān)鍵,就是將客戶端添加到給定 channel 的訂閱鏈表中。
通過(guò) PUBLISH 命令向訂閱者發(fā)送消息,redis-server 會(huì)使用給定的頻道作為鍵,在它所維護(hù)的 channel字典中查找記錄了訂閱這個(gè)頻道的所有客戶端的鏈表,遍歷這個(gè)鏈表,將消息發(fā)布給所有訂閱者。
Pub/Sub 從字面上理解就是發(fā)布(Publish)與訂閱(Subscribe),在Redis中,你可以設(shè)定對(duì)某一個(gè)key值進(jìn)行消息發(fā)布及消息訂閱,當(dāng)一個(gè)key值上進(jìn)行了消息發(fā)布后,所有訂閱它的客戶端都會(huì)收到相應(yīng)的消息。這一功能最明顯的用法就是用作實(shí)時(shí)消息系統(tǒng),比如普通的即時(shí)聊天,群聊等功能。
使用場(chǎng)景
Pub/Sub構(gòu)建實(shí)時(shí)消息系統(tǒng)。
Redis的Pub/Sub系統(tǒng)可以構(gòu)建實(shí)時(shí)的消息系統(tǒng)。
比如很多用Pub/Sub構(gòu)建的實(shí)時(shí)聊天系統(tǒng)的例子。

浙公網(wǎng)安備 33010602011771號(hào)