设为首页 收藏本站
查看: 1850|回复: 0

[经验分享] 使用python监控redis

[复制链接]
累计签到:8 天
连续签到:1 天
发表于 2015-7-23 09:23:28 | 显示全部楼层 |阅读模式
  无聊的时候,写的一个小监控脚本,适用于nagios
  目前脚本可以监控 redis内存使用率,fork时间
  脚本使用方法:
  监控内存使用率
  ./check_redis.py -H 192.168.1.100 -p 6379 -C memuse -w 80 -c 90
  
  监控上次fork消耗时间(通常redis在进行fork时,redis服务的响应会有影响)
  ./check_redis.py -H 192.168.1.100 -p 6379 -C fork -w 3 -c 5

  
  cat check_redis.py

  • #!/bin/env python
  • #-*-encoding=utf8-*-
  • __author__ = 'songtao'

  •            

  • import redis
  • import sys
  • import getopt


  • def usage():
  •     print """  
  •     -H  127.0.0.1
  •     -p  6379
  •     -C  [memuse|fork]
  •     -w 50
  •     -c 80
  •     ./check_redis.py -H 127.0.0.1 -p 6379 -C memuse -c 80 -w 90
  •     """
  •     sys.exit(3)
  • #def conn_redis(host,port):
  • #    r = redis.Redis(hosthost=host,portport=port)
  • #    if r.ping():
  • #        r = redis.Redis(hosthost=host,portport=port)
  • #        return r
  • #    else:
  • #        print "can not connect!!"
  • #        sys.exit(0)
  • #r = redis.Redis(hosthost=host,portport=port)

  • warning = 80
  • critical = 90


  • def memused():
  •     maxmem = r.config_get()['maxmemory']
  •     usedmem = r.info()['used_memory']
  •     result = float(usedmem) / float(maxmem) * 100
  •     if result >=warning and result < critical:
  •         print "Warning!;mem_used:%.2f%%|mem_used:%.2f%%" % (result,result)
  •         sys.exit(1)
  •     elif result > critical:
  •         print "Critical!;mem_used:%.2f%%|mem_used:%.2f%%" % (result,result)
  •         sys.exit(2)
  •     else:
  •         print "OK!;mem_used:%.2f%%|mem_used:%.2f%%" % (result,result)
  •         sys.exit(0)


  • def redis_fork():
  •     fork_used = r.info()['latest_fork_usec'] / 1000
  •     result = float(fork_used) / 1000
  •     if result >=warning and result < critical:
  •         print "Warning!;latest_fork:%.2f%%|latest_fork:%.2f%%" % (result,result)
  •         sys.exit(1)
  •     elif result > critical:
  •         print "Critical!;latest_fork:%.2f%%|latest_fork:%.2f%%" % (result,result)
  •         sys.exit(2)
  •     else:
  •         print "OK!;latest_fork:%.2f%%|latest_fork:%.2f%%" % (result,result)
  •         sys.exit(0)


  • if "__main__" == __name__:
  •     try:
  •         opts,args = getopt.getopt(sys.argv[1:],"h:H:p:C:w:c:")
  •         for opt,arg in opts:
  •             if opt in ("-h","--help"):
  •                 usage()
  •             if opt in ("-H","--host"):
  •                 host = arg
  •             if opt in ("-p","--port"):
  •                 port = int(arg)
  •             if opt in ("-C","--command"):
  •                 cmd = arg
  •             if opt in ("-w","--warning"):
  •                 warning = float(arg)
  •             if opt in ("-c","--critical"):
  •                critical = float(arg)
  •     except:
  •         print "please check the host or opts"
  •         usage()
  •         sys.exit(3)

  • #   print opts
  • #   print args
  • #        print "host is %s ,port is %s,cmd is %s,warning is %s,critical is %s" % (host,port,cmd,warning,critical)
  •     try:
  •         r = redis.Redis(hosthost=host,portport=port)
  •         r.ping()
  •     except:
  •         print "redis can not connected or command is error"
  •         usage()
  •         sys.exit(3)
  •     if cmd == "memuse":
  •         memused()
  •     if cmd == "fork":
  •         redis_fork()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-89702-1-1.html 上篇帖子: 几点建议,让Redis在你的系统中发挥更大作用(转) 下篇帖子: Linux下Redis的安装、配置操作说明
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表