利用redis的订阅和发布来实现实时监控的一个DEMO(Python版本)

9 篇文章 0 订阅
5 篇文章 0 订阅

       redis的list类型有个很好的特性,就是每次添加元素后会返回当前list的长度,利用这个特点,我们可以监控它的长度,比如我们的key是用户注册的IP地址,list中存放的是已经在此IP地址上注册的用户的ID,当用户数超过1000的时候来发一个告警,而redis的订阅和发布功能就能帮你很轻松地实现通知监控程序。

第一步,下载需要的软件:

    redis:  http://redis.googlecode.com/files/redis-2.6.14.tar.gz

    redis-py:  https://github.com/andymccurdy/redis-py/archive/master.zip

第二步,编写客户端client.py:

#!/usr/bin/env python
#coding=utf-8
import redis

if __name__ == "__main__":

    rc = redis.Redis(host='10.250.2.18',port=6379,db=0,password='master123')
    ip_addr = "192.168.1.100"
    for i in xrange(500):
        count = rc.lpush("ip:192.168.1.100",i)
        if count > 1000:
            rc.publish("count_alarm", count)
            rc.publish('ip_alarm', ip_addr)

           


如果没有设置redis的密码,可以删除password属性【默认没有配置】

第三步,编写服务端 server.py:

#!/usr/bin/env python
#coding=utf-8

import redis

rc = redis.Redis(host='10.250.2.18',port=6379,db=0,password='master123')
ps = rc.pubsub()
ps.subscribe(['count_alarm', 'ip_alarm'])  #订阅两个频道,分别是count_alarm ip_alarm


for item in ps.listen():


    if item['type'] == 'message':
        print item['channel'] , item['data'] # 此处就可以做和监控相关的事了,比如发邮件通知、短信通知或者IM通知等等


第四步,查看效果

运行server.py:

python server.py

运行client.py:

python client.py

client.py会马上结束,而server.py会一直监听,一个简单的DEMO就做好了


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值