什么是Redis pubsub以及如何使用它?

时间:2011-06-26 23:24:47

标签: redis publish-subscribe

有人问我PubSub是什么以及如何创建频道(来自my answer的评论)我向他指出了关于redis.io =>的文章。 http://redis.io/topics/pubsub。我认为这很清楚,但我想知道是否有人有更好的解释。理想情况下,使用redis-cli清楚地描述它。

1 个答案:

答案 0 :(得分:85)

发布/订阅是一个非常简单的范例。想想它就像你在电台播放脱口秀一样。这是PUBLISH。你希望至少有一个或多个人拿起你的频道在广播节目(SUBSCRIBE)上听你的消息,甚至可能做一些事情,但你不是直接与人们交谈

让我们与redis-cli玩得开心!

redis 127.0.0.1:6379> PUBLISH myradioshow "Good morning everyone!"
(integer) 0
redis 127.0.0.1:6379> PUBLISH myradioshow "How ya'll doin tonight?"
(integer) 0
redis 127.0.0.1:6379> PUBLISH myradioshow "Hello? Is anyone listening? I'm not wearing pants."
(integer) 0

请注意,没有客户端在“myradioshow”频道上接收消息(响应中为0)。没有人在听。现在,打开另一个redis-cli(或者更有趣的时候让朋友打开他们的redis-cli并连接到你的服务器)和SUBSCRIBE到频道:

redis 127.0.0.1:6379> SUBSCRIBE myradioshow
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "myradioshow"
3) (integer) 1

回到原来的redis-cli并继续你的节目:

redis 127.0.0.1:6379> PUBLISH myradioshow "Next caller gets a free loaf of bread!"
(integer) 1

注意结尾的“1”?你有一个听众!像魔术一样,在你的SUBSCRIBE-d终端中:

1) "message"
2) "myradioshow"
3) "Next caller gets a free loaf of bread!"

当然,实际上,您可能希望做的事情比告诉客户您的无裤生活方式更有用,例如在您的服务器上触发事件或运行某种任务/工作。也许不是! :)