Redis 发布订阅

 

Redis 发布订阅(pub/sub)是一种消息通讯模式:发送者(pub)发送消息,订阅者(sub)接收消息。redis

pub即publish,推送。服务器

sub即subscribe,订阅。微信

 

 

订阅者订阅某个channel(频道),发布者将消息发布到Redis服务器,Redis服务器将消息推送给这个频道的订阅者。spa

channel  管道、通道、频道。code

 

 

 

Redis的channel是公共频道,谁均可以发布消息。blog

就像微信群、QQ群,谁均可以发送消息,群成员(订阅者)都会收到消息。教程

 

Redis的消息是在线即时消息,相似于广播,只有在线的订阅者(链接到Redis服务器的订阅者),才会收到消息。class

若当时不在线,并不会收到消息。后面登录了(链接到服务器),服务器也不会推送以前(这个客户端未收到)的消息。服务器只推送一遍。cli

 

 

 

 

使用示例

一、启动一个客户端,链接到服务器

 redis-cli -a password 书籍

 

二、订阅频道

 subscribe channel1 channel2 .....     //可订阅一个或多个频道

 

 

会显示订阅的频道的信息,一个频道显示3个条目:

(1)"subscribe"      //固定的值,表示这是一个订阅频道

(2)订阅的频道名

(3)一个int型的数,表示这个频道是当前客户端订阅的第几个频道

 

订阅以后,当前命令提示符会阻塞,只能接收Redis服务器推送的消息,不能再执行命令。因此咱们再启动一个客户端推送消息。

 

三、在另外一个Redis客户端推送消息

 publish channel message    //channel指定要推送消息到哪一个频道,message是要推送的消息

返回当前接收到消息的订阅者的数量。1表示只有一个订阅者收到了这条消息。

 

咱们看到另外一个客户端已接收到消息。一条消息显示3个项:

(1)“message”   //固定值,表示这是一条消息

(2)这条消息来自哪一个订阅频道

(3)消息内容

 

 

Redis的订阅是临时订阅,只在本次链接期间有效。断开链接后,会清除这个客户端的订阅信息,即取消全部订阅的频道。

 

谁均可以是发布者,谁均可以发送消息。能够向任何频道发送消息。

 

 

 

 

相关命令

一、subscribe  channel1  channel2  ......      //订阅一个或多个频道

 

二、unsubscribe  channel1  channel2  .......    //退订一个或多个频道。多了un

 

 

三、psubscribe  pattern1  pattern2  .....     //多了一个p,即pattern,订阅该模式匹配的全部频道,能够有多个匹配模式。

示例:

 psubscribe tv     //订阅频道tv

 psubscribe *home    //订阅全部以home结尾的频道

 psubscribe china*    //订阅全部以china开头的频道

 

四、punsubscribe  pattern1  pattern2  .....     //退订符合匹配的全部频道,可指定多个匹配模式,知足pattern1或者知足pattern2.....,,注意是或。

 

 

五、publish  channel  message   //推送消息到某个频道

 

红色的命令是经常使用的。

 

 

 

不少书籍、教程中,关键字都使用全大写,这样作是为了好区分关键字。其实关键字是大小写等价的。

相关文章
相关标签/搜索