ディレクトリ 検索
Redis 基础教程 Redis 教程 Redis 安装 Redis 配置 Redis 数据类型 Redis 命令 Redis 命令 Redis 键(key) Redis DEL 命令 Redis Dump 命令 Redis EXISTS 命令 Redis Expire 命令 Redis Expireat 命令 Redis PEXPIREAT 命令 Redis PEXPIREAT 命令 Redis Keys 命令 Redis Move 命令 Redis PERSIST 命令 Redis Pttl 命令 Redis TTL 命令 Redis RANDOMKEY 命令 Redis Rename 命令 Redis Renamenx 命令 Redis Type 命令 Redis 字符串(String) Redis SET 命令 Redis Get 命令 Redis Getrange 命令 Redis Getset 命令 Redis Getbit 命令 Redis Mget 命令 Redis Setbit 命令 Redis Setex 命令 Redis Setnx 命令 Redis Setrange 命令 Redis Strlen 命令 Redis Mset 命令 Redis Msetnx 命令 Redis Psetex 命令 Redis Incr 命令 Redis Incrby 命令 Redis Incrbyfloat 命令 Redis Decr 命令 Redis Decrby 命令 Redis Append 命令 Redis 哈希(Hash) Redis Hdel 命令 Redis Hexists 命令 Redis Hget 命令 Redis Hgetall 命令 Redis Hincrby 命令 Redis Hincrbyfloat 命令 Redis Hkeys 命令 Redis Hlen 命令 Redis Hmget 命令 Redis Hmset 命令 Redis Hset 命令 Redis Hsetnx 命令 Redis Hvals 命令 Redis 列表(List) Redis Blpop 命令 Redis Brpop 命令 Redis Brpoplpush 命令 Redis Lindex 命令 Redis Linsert 命令 Redis Llen 命令 Redis Lpop 命令 Redis Lpush 命令 Redis Lpushx 命令 Redis Lrange 命令 Redis Lrem 命令 Redis Lset 命令 Redis Ltrim 命令 Redis Rpop 命令 Redis Rpoplpush 命令 Redis Rpush 命令 Redis Rpushx 命令 Redis 集合(Set) Redis Sadd 命令 Redis Scard 命令 Redis Sdiff 命令 Redis Sdiffstore 命令 Redis Sinter 命令 Redis Sinterstore 命令 Redis Sismember 命令 Redis Smembers 命令 Redis Smove 命令 Redis Spop 命令 Redis Srandmember 命令 Redis Srem 命令 Redis Sunion 命令 Redis Sunionstore 命令 Redis Sscan 命令 Redis 有序集合(sorted set) Redis Zadd 命令 Redis Zcard 命令 Redis Zcount 命令 Redis Zincrby 命令 Redis Zinterstore 命令 Redis Zlexcount 命令 Redis Zrange 命令 Redis Zrangebylex 命令 Redis Zrangebyscore 命令 Redis Zrank 命令 Redis Zrem 命令 Redis Zremrangebylex 命令 Redis Zremrangebyrank 命令 Redis Zremrangebyscore 命令 Redis Zrevrange 命令 Redis Zrevrangebyscore 命令 Redis Zrevrank 命令 Redis Zscore 命令 Redis Zunionstore 命令 Redis Zscan 命令 Redis HyperLogLog Redis Pfadd 命令 Redis Pfcount 命令 Redis Pgmerge 命令 Redis 发布订阅 Redis Psubscribe 命令 Redis Pubsub 命令 Redis Publish 命令 Redis Punsubscribe 命令 Redis Subscribe 命令 Redis Unsubscribe 命令 Redis 事务 Redis Discard 命令 Redis Exec 命令 Redis Multi 命令 Redis Unwatch 命令 Redis Watch 命令 Redis 脚本 Redis Eval 命令 Redis Evalsha 命令 Redis Script Exists 命令 Redis Script Flush 命令 Redis Script kill 命令 Redis Script Load 命令 Redis 连接 Redis Auth 命令 Redis Echo 命令 Redis Ping 命令 Redis Quit 命令 Redis Select 命令 Redis 服务器 Redis Bgrewriteaof 命令 Redis Bgsave 命令 Redis Client Kill 命令 Redis Client List 命令 Redis Client Getname 命令 Redis Client Pause 命令 Redis Client Setname 命令 Redis Cluster Slots 命令 Redis Command 命令 Redis Command Count 命令 Redis Command Getkeys 命令 Redis Time 命令 Redis Command Info 命令 Redis Config Get 命令 Redis Config rewrite 命令 Redis Config Set 命令 Redis Config Resetstat 命令 Redis Dbsize 命令 Redis Debug Object 命令 Redis Debug Segfault 命令 Redis Flushall 命令 Redis Flushdb 命令 Redis Info 命令 Redis Lastsave 命令 Redis Monitor 命令 Redis Role 命令 Redis Save 命令 Redis Shutdown 命令 Redis Slaveof 命令 Redis Showlog 命令 Redis Sync 命令 Redis 高级教程 Redis 数据备份与恢复 Redis 安全 Redis 性能测试 Redis 客户端连接 Redis 管道技术 Redis 分区 Java 使用 Redis PHP 使用 Redis
テキスト

Redis 发布订阅


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

Redis 客户端可以订阅任意数量的频道。

下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:

pubsub1

当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:

pubsub2

实例

以下实例演示了发布订阅是如何工作的。在我们实例中我们创建了订阅频道名为 redisChat:

redis 127.0.0.1:6379> SUBSCRIBE redisChat

Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1

现在,我们先重新开启个 redis 客户端,然后在同一个频道 redisChat 发布两次消息,订阅者就能接收到消息。

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"

(integer) 1

redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by shouce.ren"

(integer) 1

# 订阅者的客户端会显示如下消息
1) "message"
2) "redisChat"
3) "Redis is a great caching technique"
1) "message"
2) "redisChat"
3) "Learn redis by shouce.ren"

Redis 发布订阅命令

下表列出了 redis 发布订阅常用命令:

序号 命令及描述
1 PSUBSCRIBE pattern [pattern ...]
订阅一个或多个符合给定模式的频道。
2 PUBSUB subcommand [argument [argument ...]]
查看订阅与发布系统状态。
3 PUBLISH channel message
将信息发送到指定的频道。
4 PUNSUBSCRIBE [pattern [pattern ...]]
退订所有给定模式的频道。
5 SUBSCRIBE channel [channel ...]
订阅给定的一个或多个频道的信息。
6 UNSUBSCRIBE [channel [channel ...]]
指退订给定的频道。
前の記事: 次の記事: