前面一篇写了数据同步和模板绑定,zabbix其实能做的事还蛮多。
zabbix提供了一个非常好的前端展示页面,但是我们总觉得不太好看;我们可以进一步调用他的api通过获取每一个监控项的历史数据,然后打到我们的监控平台上;主流的有rrdtool方式和highcharts方式;rrdtool略显复杂,还要学习rrdtool之类的几个聚合方式。相对而言我更喜欢highcharts的方式,出图简便,只需要提供数据和时间戳组成的json数据就够了,之前也介绍过具体;那么这里我们先拿出我们想要的数据。
zabbix的api读取方式如下:
1、通过post方式传入用户名密码获取token秘钥。
2、获取所有主机的hostid和name。
3、通过hostid获取每个监控项目的item和对应的key。
4、通过传入的itemid获取相对应的历史数据。
以上步骤都是需要传入token才能执行操作,pipy已经提供了第三方插件,让我们省去了这一部分的操作;具体参考:https://pypi.python.org/pypi/zabbix-client/0.1.1;zabbix api文档请参考官方文档。想多写点代码可以看小马哥的博客:http://www.xiaomastack.com/2014/08/17/rrdtool-1/。
1、获取主机的代码:
def get_hosts(self):
data = {
"output": ["hostid", "name"]
}
ret = self.zb.host.get(**data)
return ret
执行结果:
2、获取每个主机对应的监控项和监控项具体名称:
def item_get(self, hostids="10109"):
data = {
"output":["itemids","key_"],
"hostids": hostids,
}
ret = self.zb.item.get(**data)
return ret
执行结果:
3、获取对应的历史数据:
def history_get(self, itemid, i ,limit=10):
data = { "output": "extend",
"history": i,
"itemids": itemid,
"sortfield": "clock",
"sortorder": "DESC",
"limit": limit
}
ret = self.zb.history.get(**data)
return ret
具体代码:
from zabbix_client import ZabbixServerProxy
class Zabbix():
def __init__(self):
self.zb = ZabbixServerProxy("http://192.168.10.100/zabbix")
self.zb.user.login(user="Admin", password="zabbix")
def get_hosts(self):
data = {
"output": ["hostid", "name"]
}
ret = self.zb.host.get(**data)
return ret
def item_get(self, hostids="10109"):
data = {
"output":["itemids","key_"],
"hostids": hostids,
}
ret = self.zb.item.get(**data)
return ret
def history_get(self, itemid, i ,limit=10):
###history参数中有0,1,2,3,4表示:float,string,log,integer,text
data = { "output": "extend",
"history": i,
"itemids": itemid,
"sortfield": "clock",
"sortorder": "DESC",
"limit": limit
}
ret = self.zb.history.get(**data)
return ret
if __name__ == "__main__":
zabbix_server = Zabbix()
# print zabbix_server.get_hosts()
print zabbix_server.history_get("24519",3)
来源:oschina
链接:https://my.oschina.net/u/4318023/blog/4293226