修改mysql触发redis_Redis-Redis如何实现类似MySQL的触发器功能?

能否用订阅模式来做呢,你说道“如果发现它的值满足某种条件则会做相关的一些操作...”,应该有一端在修改这个值吧,同时触发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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值