监控redis python脚本

#!/bin/env python
#-*- coding:utf-8 -*-

import json
import time
import socket
import os
import re
import sys
import commands
import urllib2, base64
import requests

class RedisStats:
    redis_cli = '/data/redis/bin/redis-cli'
    stat_regex = re.compile(ur'(\w+):([0-9]+\.?[0-9]*)\r')

    def __init__(self,port='6379',host='127.0.0.1',status='info'):
        self.cmd = '%s -h %s -p %s %s' % (self.redis_cli, host, port,status)

    def stats(self):
        info = commands.getoutput(self.cmd)
        return dict(self.stat_regex.findall(info))

def main():
    timestamp = int(time.time())
    step = 60
    
    p = []
    
    monit_keys = [
        ('connected_clients','GAUGE'), 
        ('blocked_clients','GAUGE'), 
        ('used_memory','GAUGE'),
        ('used_memory_rss','GAUGE'),
        ('mem_fragmentation_ratio','GAUGE'),
        ('total_commands_processed','COUNTER'),
        ('rejected_connections','COUNTER'),
        ('expired_keys','COUNTER'),
        ('evicted_keys','COUNTER'),
        ('keyspace_hits','COUNTER'),
        ('keyspace_misses','COUNTER'),
        ('keyspace_hit_ratio','GAUGE'),
    ]
    
    insts_list = [ '/etc/redis/6379.conf' ]
  
    with open('./cfg.json') as f:
    data = f.read().replace('\n','')
    jsonlist = json.loads(data)
        hostpoint = jsonlist['hostname']

    port = "6979"
    metric = "redis"
    endpoint = '%s' %(hostpoint)
    tags = 'port=%s' %(port)

    conn = RedisStats()
    stats = conn.stats()

    for key,vtype in monit_keys:
        if key == 'keyspace_hit_ratio':
            try:
                value = float(stats['keyspace_hits'])/(int(stats['keyspace_hits']) + int(stats['keyspace_misses']))
            except ZeroDivisionError:
                value = 0
        elif key == 'mem_fragmentation_ratio':
            value = float(stats[key])
        else:
            try:
                value = int(stats[key])
            except:
                continue

        i = {
            'Metric': '%s.%s' % (metric, key),
            'Endpoint': endpoint,
            'Timestamp': timestamp,
            'Step': step,
            'Value': value,
            'CounterType': vtype,
            'TAGS': tags
        }
        p.append(i)
        

    print json.dumps(p, sort_keys=True,indent=4)
    method = "POST"
    handler = urllib2.HTTPHandler()
    opener = urllib2.build_opener(handler)
    url = 'http://127.0.0.1:1988/v1/push'
    request = urllib2.Request(url, data=json.dumps(p) )
    request.add_header("Content-Type",'application/json')
    request.get_method = lambda: method
    try:
        connection = opener.open(request)
    except urllib2.HTTPError,e:
        connection = e

   # check. Substitute with appropriate HTTP code.
    if connection.code == 200:
        print connection.read()
    else:
        print '{"err":1,"msg":"%s"}' % connection
if __name__ == '__main__':
   # proc = commands.getoutput(' ps -ef|grep %s|grep -v grep|wc -l ' % os.path.basename(sys.argv[0]))
   # if int(proc) < 5:
   #     main()
    main()

 

posted @ 2016-10-19 22:32  fengjian1585  阅读(2680)  评论(0编辑  收藏  举报