Redis 发布订阅
redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。
pub即publish,推送。
sub即subscribe,订阅。
订阅者订阅某个channel(频道),发布者将消息发布到redis服务器,redis服务器将消息推送给这个频道的订阅者。
channel 管道、通道、频道。
redis的channel是公共频道,谁都可以发布消息。
就像微信群、qq群,谁都可以发送消息,群成员(订阅者)都会收到消息。
redis的消息是在线即时消息,类似于广播,只有在线的订阅者(连接到redis服务器的订阅者),才会收到消息。
若当时不在线,并不会收到消息。后面登陆了(连接到服务器),服务器也不会推送之前(这个客户端未收到)的消息。服务器只推送一遍。
使用示例
1、启动一个客户端,连接到服务器
redis-cli -a password
2、订阅频道
subscribe channel1 channel2 ..... //可订阅一个或多个频道
会显示订阅的频道的信息,一个频道显示3个条目:
(1)"subscribe" //固定的值,表示这是一个订阅频道
(2)订阅的频道名
(3)一个int型的数,表示这个频道是当前客户端订阅的第几个频道
订阅之后,当前命令提示符会阻塞,只能接收redis服务器推送的消息,不能再执行命令。所以我们再启动一个客户端推送消息。
3、在另一个redis客户端推送消息
publish channel message //channel指定要推送消息到哪个频道,message是要推送的消息
返回当前接收到消息的订阅者的数量。1表示只有一个订阅者收到了这条消息。
我们看到另一个客户端已接收到消息。一条消息显示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 //推送消息到某个频道
红色的命令是常用的。
很多书籍、教程中,关键字都使用全大写,这样做是为了好区分关键字。其实关键字是大小写等价的。
上一篇: 朱高煦作为朱棣的亲生儿子 他是怎么将自己活活作死死掉的
下一篇: JAVA基础之线程