Redis-Redis如何实现类似MySQL的触发器功能?
我现在有个程序会隔一段时间在redis库中请求一次某个key,如果发现它的值满足某种条件则会做相关的一些操作。但是总觉得这种做法不够智能和优雅,不知道Redis中是否能够实现类似MySQL的触发器那样的功能,只要该key满足某个条件则会自动触发相关操作?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
Redis没有提供触发器的功能,它只是存取数据,连Redis自己内部的master/slave同步都是slave通过定时任务ServerCron服务向Master发送Sync请求。所以如果要实现满足条件触发,还是写个Linux下的Cron来定时检测内存某个Key的变化,除了这样好像没有其它的办法。
能否用订阅模式来做呢,你说道“如果发现它的值满足某种条件则会做相关的一些操作...”,应该有一端在修改这个值吧,同时触发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
redis本身不提供触发器功能,我也觉得二次开发比较好,嵌个lua脚本在里面。httpserver现在还支持嵌lua脚本呢