前提准备:
1.使用python requests模块
2.了解json
3.zabbix api的具体调用建议先浏览一下官网
先上代码:
import requests,json # #url一定要正确,IP地址换成自己zabbix服务器的 zbx_url = "http://192.168.60.130:3080/zabbix/api_jsonrpc.php" #在post请求头部必须要有 'Content-Type': 'application/json-rpc' headers = {'Content-Type': 'application/json-rpc'} #传递json 数据到api;登录 login = { "jsonrpc": "2.0", "method": "user.login", "params": { "user": "Admin", "password": "zabbix" }, "id": 1 } #首次登陆不用在json字段中写 auth,否则会有相关的报错 #将数据发送到api ret = requests.post(zbx_url, data=json.dumps(login), headers=headers) #对结果进行序列化 ret = ret.json() auth = ret['result'] #获取问题主机json data = { "jsonrpc": "2.0", "method":"trigger.get", "params": { # output表示输出结果包含参数有哪些 "output": [ "triggerid", "description", "status", "value", "priority", "lastchange", "recovery_mode", "hosts", "state", ], "selectHosts": "hosts", # 需包含主机ID信息,以便于根据主机ID查询主机信息 "selectItems":"items", "filter": { # 筛选条件 "value": 1,#value值为1表示有问题 "status": 0#status为0表示已启用的trigger }, }, "auth":auth,#这里的auth就是登录后获取的 'id':'1'#这个id可以随意 } #将查询数据发送到zabbix-server ret = requests.post(zbx_url,data=json.dumps(data),headers=headers) respone_result = ret.json()['result']#对结果进行json序列化 print(respone_result)
下面简单介绍一下上诉代码:
要调用zabbix api获取数据,首先要获得auth这一串字符用户后续的内容获取,auth可以看做是一种你与zabbix-server之间的"暗号";
登录的json内容之所以这样写是zabbix官方规定的,json字符串里面千万不能使用tab键。
login = { "jsonrpc": "2.0", "method": "user.login", "params": { "user": "Admin", #根据自己的情况填 "password": "zabbix" #根据自己的条件填写 }, "id": 1 }
获取问题主机的json字符串建议先浏览一下官网的说明,要强调的是output和filter这两个key,output就是zabbix api返回来的内容,filter相当于是过滤条件:
"filter": { # 筛选条件 "value": 1, #value值为1表示有问题 "status": 0 #status为0表示已启用的trigger },
上诉代码表示 value=1 and status=0,是一种与关系,很像查数据库表时候的过滤操作。
强烈建议先大概浏览一下官网文档
PS:Python通过Zabbix API获得数据的方法
Zabbix API查询:https://www.zabbix.com/documentation/2.0/manual/appendix/api/api
import json,urllib2 from urllib2 import Request, urlopen, URLError, HTTPError #url and url header #zabbix的api 地址,用户名,密码,这里修改为自己实际的参数 zabbix_url="http://10.16.2.40/zabbix/api_jsonrpc.php" zabbix_header = {"Content-Type":"application/json"} zabbix_user = "admin" zabbix_pass = "password" auth_code = "" #auth user and password #用户认证信息的部分,最终的目的是得到一个SESSIONID #这里是生成一个json格式的数据,用户名和密码 auth_data = json.dumps( { "jsonrpc":"2.0", "method":"user.login", "params": { "user":zabbix_user, "password":zabbix_pass }, "id":0 }) # create request object request = urllib2.Request(zabbix_url,auth_data) for key in zabbix_header: request.add_header(key,zabbix_header[key]) try: result = urllib2.urlopen(request) #对于出错新的处理 except HTTPError, e: print 'The server couldn\'t fulfill the request, Error code: ', e.code except URLError, e: print 'We failed to reach a server.Reason: ', e.reason else: response=json.loads(result.read()) print response result.close() #判断SESSIONID是否在返回的数据中 if 'result' in response: auth_code=response['result'] else: print response['error']['data'] # request json #用得到的SESSIONID去通过验证,获取主机的信息(用http.get方法) if len(auth_code) <> 0: host_list=[] get_host_data = json.dumps( { "jsonrpc":"2.0", "method":"host.get", "params":{ "output": "extend", }, "auth":auth_code, "id":1, }) # create request object request = urllib2.Request(zabbix_url,get_host_data) for key in zabbix_header: request.add_header(key,zabbix_header[key]) # get host list try: result = urllib2.urlopen(request) except URLError as e: if hasattr(e, 'reason'): print 'We failed to reach a server.' print 'Reason: ', e.reason elif hasattr(e, 'code'): print 'The server could not fulfill the request.' print 'Error code: ', e.code else: response = json.loads(result.read()) result.close() #将所有的主机信息显示出来 for r in response['result']: # print r['hostid'],r['host'] host_list.append(r['hostid']) #显示主机的个数 print "Number Of Hosts: ", len(host_list) #返回所有hostid==10251的主机,并只查询name包含“CPU Usage”字段的item,并按照name排序 get_item_data = json.dumps({ "jsonrpc": "2.0", "method": "item.get", "params": { "output": "extend", "hostids": "10251" "search": { #"key_": 'perf_counter[\Processor Information(_Total)\% Processor Time]' "name": "CPU Usage" }, "sortfield": "name" }, "auth": auth_code, "id": 1 }) request = urllib2.Request(zabbix_url,get_item_data) for key in zabbix_header: request.add_header(key,zabbix_header[key]) result = urllib2.urlopen(request) try: result = urllib2.urlopen(request) response = json.loads(result.read()) for r in response['result']: print r['itemid'],r['hostid'] result.close() except: pass #通过hostid获取相应的graphid get_graph_data = json.dumps({ "jsonrpc": "2.0", "method": "graphitem.get", "params": { "output": "extend", "expandData": 1, "itemids": "33712" }, "auth": auth_code, "id": 1 }) request = urllib2.Request(zabbix_url,get_graph_data) for key in zabbix_header: request.add_header(key,zabbix_header[key]) result = urllib2.urlopen(request) try: result = urllib2.urlopen(request) response = json.loads(result.read()) for r in response['result']: print r['itemid'],r['graphid'] result.close() except: pass
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]