Redis 发布订阅

栏目: 数据库 · 发布时间: 4年前

内容简介:Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。pub即publish,推送。sub即subscribe,订阅。

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

pub即publish,推送。

sub即subscribe,订阅。

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

channel  管道、通道、频道。

Redis 发布订阅

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

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

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

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

使用示例

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

redis-cli -a password

2、订阅频道

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

Redis 发布订阅

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

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

(2)订阅的频道名

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

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

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

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

Redis 发布订阅

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

Redis 发布订阅

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

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

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

(3)消息内容

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

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

相关命令

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

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

3、psubscribe  pattern1  pattern2  .....     //多了一个p,即pattern,订阅该模式匹配的所有频道,可以有多个匹配模式。

示例:

psubscribe tv //订阅频道tv

psubscribe *home //订阅所有以home结尾的频道

psubscribe china* //订阅所有以china开头的频道

4、punsubscribe  pattern1  pattern2  .....     //退订符合匹配的所有频道,可指定多个匹配模式,满足pattern1或者满足pattern2.....,,注意是或。

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

红色的命令是常用的。

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


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

云经济学

云经济学

乔·韦曼 (Joe Weinman) / 人民邮电出版社 / 2014-7-1 / CNY 75.00

在云计算日益成熟的今天,“接入而非拥有”的理念不断为人们所理解和接受。 《云经济学》阐述了“云经济学”不是经济理论中深奥的数学模型,而是技术革命的生动概括。“灵活的云计算能够有效提升企业的商业价值”则是本书的核心理念。 《云经济学——企业云计算战略与布局》从商业、金融及经济的视角解释了云经济的潜在原理,并通过易于理解的案例阐述了云计算是如何创造出综合价值的。无论你是供应商、零售商、服务......一起来看看 《云经济学》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

SHA 加密
SHA 加密

SHA 加密工具