Redis中消息的发布和订阅

知识回顾:

通过对Redis中的String的命令做了充分的讲解以及实践学习
通过对Redis中String类型之Bit命令的详解以及Bit命令的实践进行了学习
通过对Redis中的Hash类型以及Hash中常用命令的实践学习
通过对Redis之List类型的详解&List类型中常用命令的实践的学习
通过对Redis之Set类型的详解&Set类型中常用命令的实践的学习
通过对Redis之ZSet类型的详解&ZSet类型中常用命令的实践的学习
接下来的学习任务:
接下来我们要学习的内容是:Redis中消息的订阅和发布。

Redis中消息的发布和订阅

Redis 发布订阅(pub/sub)是一种消息通信模式:
发送者----》publish----》发送消息
订阅者----》subscribe----》接收消息
Redis客户端中的订阅者可以订阅任意数量的频道。
Redis客户端中的发送者可以给指定的通道发送消息。

subscribe订阅消息命令实践

订阅指定的通道 :

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

redis订阅模式的可靠性_消息订阅者subscribe

接收到发送publish给指定的通达发送来的消息。

127.0.0.1:6379> subscribe channel1 channel2 channel3
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel1"
3) (integer) 1
1) "subscribe"
2) "channel2"
3) (integer) 2
1) "subscribe"
2) "channel3"
3) (integer) 3
1) "message"
2) "channel1"
3) "hello redis!"
1) "message"
2) "channel2"
3) "hello redis!"
1) "message"
2) "channel3"
3) "this is a message "

redis订阅模式的可靠性_缓存_02

publish发送消息

给指定的通道发送消息:

127.0.0.1:6379> publish channel1 "hello redis!"
(integer) 1
127.0.0.1:6379> publish channel2 "hello redis!"
(integer) 1
127.0.0.1:6379> publish channel3 "this is a message "
(integer) 1
127.0.0.1:6379>

redis订阅模式的可靠性_redis订阅模式的可靠性_03

模式订阅消息

客户端在订阅消息的时候还可以通过模式匹配订阅的方式订阅
订阅管道是channel*的模糊匹配

127.0.0.1:6379> psubscribe channel*
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "channel*"
3) (integer) 1
1) "pmessage"
2) "channel*"
3) "channel1"
4) "hello redis!"
1) "pmessage"
2) "channel*"
3) "channel3"
4) "this is a message "

redis订阅模式的可靠性_redis订阅模式的可靠性_04

发布消息:
给channel名字开头的管道发送消息,可以被接受。
如果管道是其它名字,则不可以被接受。

127.0.0.1:6379> publish channel1 "hello redis!"
(integer) 1
127.0.0.1:6379> publish channel3 "this is a message "
(integer) 1
127.0.0.1:6379> publish t "redis"
(integer) 0
127.0.0.1:6379>

redis订阅模式的可靠性_redis订阅模式的可靠性_05