能否用订阅模式来做呢,你说道“如果发现它的值满足某种条件则会做相关的一些操作...”,应该有一端在修改这个值吧,同时触发publish动作,有订阅该channel的client就会收到消息。
搬运自:http://www.redisbook.com/en/latest/feature/pubsub.html
Redis 通过 PUBLISH 、 SUBSCRIBE 等命令实现了订阅与发布模式, 这个功能提供两种信息机制, 分别是订阅/发布到频道和订阅/发布到模式, 下文先讨论订阅/发布到频道的实现, 再讨论订阅/发布到模式的实现。
频道的订阅与信息发送
Redis 的 SUBSCRIBE 命令可以让客户端订阅任意数量的频道, 每当有新信息发送到被订阅的频道时, 信息就会被发送给所有订阅指定频道的客户端。
作为例子, 下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:
当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:
python版代码:(荣耀属于http://guozhiwei.iteye.com/blog/1240600)
发布端:
import redis
#连接redis server
REDIS_CONN = redis.Redis(host='192.168.0.235',port=6379)
#第一个参数是你发送消息的channel,有的地方叫做topic,就像对讲机有不同的频率和频道
#第二个参数是你对这个channel发送消息的具体内容 只能是string类型的
REDIS_CONN.publish('channel_1', 'i am publishing message')
消息订阅端:
import redis
#连接redis
redis_conn = redis.Redis(host='192.168.0.235',port=6379)
#实例化一个 pubsub 对象
pubsub_ins = redis_conn.pubsub()
#订阅你关心的channel
#
# api中提供了一种批量订阅的方法
# pattern为 "ESUN*" 则表示订阅所有ESUN开头的channel
# pubsub_ins.psubscribe(pattern);
#
pubsub_ins.subscribe('channel_1')
#listen 开始收听该channel的消息 加上这句以后 redis server就会将你订阅的channel的消息发送过来了
#它将消息存储在 listen2 listen2是一个 yield
listen2 = pubsub_ins.listen()
while 1:
#next操作就会将yield中的消息一条一条的取出来了 没有消息会一直阻塞
msg = listen2.next()
print msg