#!/bin/env python
#-*- coding:utf- -*- 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='',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 = 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 = ""
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 =
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=)
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 == :
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[]))
# if int(proc) < :
# main()
main()

最新文章

  1. 【Java EE 学习 78 上】【数据采集系统第十天】【Service使用Spring缓存模块】
  2. CSipSimple配置系统
  3. javascript 红宝书笔记之操作日期
  4. 队列的C++实现(数组)——创建-进队-出队-返回队首元素-清空队列栈-处理队列
  5. JavaScript Function(函数表达式)
  6. 山寨版Quartz.Net任务统一调度框架
  7. System call in linux by C
  8. MyBatis 配置sql语句输出
  9. Linux 命令 - passwd: 更改用户密码
  10. SVN 的revert操作
  11. Vuex原来可以这样上手
  12. java之JDK的环境变量配置
  13. JavaScript 实现发布消息后,距离当前时间的实现
  14. 浅析JavaScript的prototype
  15. (转)Spring Boot(七):Mybatis 多数据源最简解决方案
  16. Kubernetes中的亲和性与反亲和性
  17. [转]ZooKeeper 集群环境搭建 (本机3个节点)
  18. 用SpringSecurity从零搭建pc项目-01
  19. 如何理解java泛型类
  20. C/C++基础----IO库

热门文章

  1. (一)洞悉linux下的Netfilter&amp;iptables:什么是Netfilter?
  2. Jquery利用Iframe实现跨子域
  3. TodoMVC中的Backbone+MarionetteJS+RequireJS例子源码分析之二 数据处理
  4. jquery点击元素之外触发事件
  5. 【BFS】POJ 2251
  6. Linux install SMplayer
  7. MSSQL 死锁查询
  8. 移植tslib1.4至mini2440
  9. ejabberd 在eclipse(erlide)中的配置、调试、运行
  10. Android sdk资源包res里面的drawable(ldpi、mdpi、hdpi、xhdpi、xxhdpi)