python调用zabbix api接口实时展示数据

简介:

    近日公司准备自已做一个运维管理平台,其中的监控部分,打算调用zabbix api接口来进行展示。

经过思考之后,计划获取如下内容:

    1、  获得认证密钥

    2、  获取zabbix所有的主机组

    3、  获取单个组下的所有主机

    4、  获取某个主机下的所有监控项

    5、  获取某个监控项的历史数据

    6、  获取某个监控项的最新数据

 

计划最后展示框架如下内容(这只是值方面,其它的会再加):

主机组1 ----主机名1---监控项1----当前值

                  ---监控项2----当前值

       ----主机名2----监控项1----当前值

                 ----监控项2----当前值

主机组2 ----主机名3---监控项1----当前值

                  ---监控项2----当前值

       ----主机名4----监控项1----当前值

                  ----监控项2----当前值

 

进入正题

1.     user.login方法获取zabbix server的认证结果

官方地址:https://www.zabbix.com/documentation/2.2/manual/api/reference/user/login

python脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
[root@yang python] # cat auth.py
#!/usr/bin/env python2.7
#coding=utf-8
import  json
import  urllib2
# based url and required header
url  =  "http://1.1.1.1/zabbix/api_jsonrpc.php"
header  =  { "Content-Type" : "application/json" }
# auth user and password
data  =  json.dumps(
{
    "jsonrpc" "2.0" ,
    "method" "user.login" ,
    "params" : {
    "user" "Admin" ,
    "password" "zabbix"
},
"id" 0
})
# create request object
request  =  urllib2.Request(url,data)
for  key  in  header:
    request.add_header(key,header[key])
# auth and get authid
try :
    result  =  urllib2.urlopen(request)
except  URLError as e:
    print  "Auth Failed, Please Check Your Name AndPassword:" ,e.code
else :
    response  =  json.loads(result.read())
    result.close()
print "Auth Successful. The Auth ID Is:" ,response[ 'result' ]

python脚本运行结果:

1
2
[root@yang python] # python auth.py
Auth Successful. The Auth  ID  Is: a0b82aae0842c2041386a61945af1180

curl命令:

1
2
3
curl  - - X POST  - 'Content-Type:application/json'  - d '{ "jsonrpc" :
"2.0" , "method" : "user.login" , "params" :{ "user" : "admin" , "password" : "zabbix" }, "auth" :
null, "id" : 0 }' http: / / 1.1 . 1.1 / zabbix / api_jsonrpc.php

curl命令运行结果:

1
{ "jsonrpc" : "2.0" , "result" : "b895ce91ba84fe247e444817c6773cc3" , "id" : 0 }

 

2.     hostgroup.get方法获取所有主机组ID

把认证密钥放到脚本中,每次获取数据时都需要认证。此处是获取zabbix server上的所有主机组名称与ID号。

官方地址:https://www.zabbix.com/documentation/2.2/manual/api/reference/hostgroup/get

python脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
[root@yang python] # catget_hostgroup_list.py
#!/usr/bin/env python2.7
#coding=utf-8
import  json
import  urllib2
# based url and required header
url  =  "http://1.1.1.1/zabbix/api_jsonrpc.php"
header  =  { "Content-Type" : "application/json" }
# request json
data  =  json.dumps(
{
    "jsonrpc" : "2.0" ,
    "method" : "hostgroup.get" ,
    "params" :{
        "output" :[ "groupid" , "name" ],
    },
    "auth" : "3c0e88885a8cf8af9502b5c850b992bd" # theauth id is what auth script returns, remeber it is string
    "id" : 1 ,
})
# create request object
request  =  urllib2.Request(url,data)
for  key  in  header:
    request.add_header(key,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()
    print  "Number Of Hosts: " len (response[ 'result' ])
    #print response
    for  group  in  response[ 'result' ]:
        print  "Group ID:" ,group[ 'groupid' ], "\tGroupName:" ,group[ 'name' ]

python脚本执行结果:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
[root@yang python] # pythonget_hostgroup_list.py
Number Of Hosts:   12
Group  ID 11     Group Name: DB Schedule
Group  ID 14     Group Name: DG - WY - KD - Server
Group  ID 5      Group Name: Discovered hosts
Group  ID 7      Group Name: Hypervisors
Group  ID 2      Group Name: Linux servers
Group  ID 8      Group Name: monitored_linux
Group  ID 9      Group Name: qsmind
Group  ID 12     Group Name: qssec
Group  ID 13     Group Name: switch
Group  ID 1      Group Name: Templates
Group  ID 6      Group Name: Virtual machines
Group  ID 4      Group Name: Zabbix servers

curl命令:

1
curl  - - X POST  - 'Content-Type:application/json'  - '{"jsonrpc": "2.0","method":"hostgroup.get","params":{"output":["groupid","name"]},"auth":"11d2b45415d5de6770ce196879dbfcf1","id": 0}'  http: / / 1.1 . 1.1 / zabbix / api_jsonrpc.php

curl执行结果:

1
{ "jsonrpc" : "2.0" , "result" :[{ "groupid" : "11" , "name" : "DBSchedule" },{ "groupid" : "14" , "name" : "DG-WY-KD-Server" },{ "groupid" : "5" , "name" : "Discoveredhosts" },{ "groupid" : "7" , "name" : "Hypervisors" },{ "groupid" : "2" , "name" : "Linuxservers" },{ "groupid" : "8" , "name" : "monitored_linux" },{ "groupid" : "9" , "name" : "qsmind" },{ "groupid" : "12" , "name" : "qssec" },{ "groupid" : "13" , "name" : "switch" },{ "groupid" : "1" , "name" : "Templates" },{ "groupid" : "6" , "name" : "Virtualmachines" },{ "groupid" : "4" , "name" : "Zabbixservers" }], "id" : 0 }

 

3.     host.get方法获取单个主机组下所有的主机ID

根据标题2中获取到的主机组id,把主机组id填入到下边脚本中,就可以获得该主机组下所有的主机id

官方地址:https://www.zabbix.com/documentation/2.2/manual/api/reference/host/get

python脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
[root@yang python] # cat get_group_one.py
#!/usr/bin/env python2.7
#coding=utf-8
import  json
import  urllib2
# based url and required header
url  =  "http://1.1.1.1/zabbix/api_jsonrpc.php"
header  =  { "Content-Type" : "application/json" }
# request json
data  =  json.dumps(
{
    "jsonrpc" : "2.0" ,
    "method" : "host.get" ,
    "params" :{
        "output" :[ "hostid" , "name" ],
        "groupids" : "14" ,
    },
    "auth" : "3c0e88885a8cf8af9502b5c850b992bd" # theauth id is what auth script returns, remeber it is string
    "id" : 1 ,
})
# create request object
request  =  urllib2.Request(url,data)
for  key  in  header:
    request.add_header(key,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()
    print  "Number Of Hosts: " len (response[ 'result' ])
    for  host  in  response[ 'result' ]:
        print  "Host ID:" ,host[ 'hostid' ], "HostName:" ,host[ 'name' ]

python脚本执行结果:

1
2
3
4
5
6
[root@yang python] # pythonget_group_one.py  
Number Of Hosts:   4
Host  ID 10146  Host Name: DG - WY - KD - 3F3B - 00
Host  ID 10147  Host Name: DG - WY - KD - 3F3B - 01
Host  ID 10148  Host Name: DG - WY - KD - 3F3B - 02
Host  ID 10149  Host Name: DG - WY - KD - 3F3B - 03

curl命令:

1
2
curl  - - X POST  - H 'Content-Type: application/json'  - '{"jsonrpc":"2.0","method":"host.get","params":{"output":["hostid","name"],"groupids":"14"},"auth":"11d2b45415d5de6770ce196879dbfcf1","id": 0}' 
http: / / 1.1 . 1.1 / zabbix / api_jsonrpc.php

curl命令执行结果:

1
{ "jsonrpc" : "2.0" , "result" :[{ "hostid" : "10146" , "name" : "DG-WY-KD-3F3B-00" },{ "hostid" : "10147" , "name" : "DG-WY-KD-3F3B-01" },{ "hostid" : "10148" , "name" : "DG-WY-KD-3F3B-02" },{ "hostid" : "10149" , "name" : "DG-WY-KD-3F3B-03" }], "id" : 0 }

 

4.     itemsid.get方法获取单个主机下所有的监控项ID

根据标题3中获取到的所有主机id与名称,找到你想要获取的主机id,获取它下面的所有items

官方地址:https://www.zabbix.com/documentation/2.2/manual/api/reference/item

python脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
[root@yang python] # cat get_items.py
#!/usr/bin/env python2.7
#coding=utf-8
import  json
import  urllib2
# based url and required header
url  =  "http://1.1.1.1/zabbix/api_jsonrpc.php"
header  =  { "Content-Type" : "application/json" }
# request json
data  =  json.dumps(
{
    "jsonrpc" : "2.0" ,
    "method" : "item.get" ,
    "params" :{
        "output" :[ "itemids" , "key_" ],
        "hostids" : "10146" ,
    },
    "auth" : "3c0e88885a8cf8af9502b5c850b992bd" # theauth id is what auth script returns, remeber it is string
    "id" : 1 ,
})
# create request object
request  =  urllib2.Request(url,data)
for  key  in  header:
    request.add_header(key,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()
    print  "Number Of Hosts: " len (response[ 'result' ])
    for  host  in  response[ 'result' ]:
        print  host
        #print "Host ID:",host['hostid'],"HostName:",host['name']

python脚本运行结果:

1
2
3
4
5
6
7
8
9
10
[root@yang python] # python get_items.py
Number Of Hosts:   54
{u 'itemid' : u '24986' , u 'key_' :u 'agent.hostname' }
{u 'itemid' : u '24987' , u 'key_' :u 'agent.ping' }
{u 'itemid' : u '24988' , u 'key_' :u 'agent.version' }
{u 'itemid' : u '24989' , u 'key_' :u 'kernel.maxfiles' }
{u 'itemid' : u '24990' , u 'key_' :u 'kernel.maxproc' }
{u 'itemid' : u '25157' , u 'key_' :u 'net.if.in[eth0]' }
{u 'itemid' : u '25158' , u 'key_' :u 'net.if.in[eth1]' }
… …

curl命令:

1
2
curl  - - X POST  - 'Content-Type:application/json'  - '{"jsonrpc":"2.0","method":"item.get","params":{"output":"itemids","hostids":"10146","search":{"key_":"net.if.out[eth2]"}},"auth":"11d2b45415d5de6770ce196879dbfcf1","id": 0}'  http: / / 1.1 . 1.1 / zabbix / api_jsonrpc.php
#此处加上了单个key的名称

curl命令执行结果:

1
{ "jsonrpc" : "2.0" , "result" :[{ "itemid" : "25154" }], "id" : 0 }

5.     history.get方法获取单个监控项的历史数据

根据第4项的获取到的所有items id的值,找到想要监控的那项,获取它的历史数据。

官方地址:https://www.zabbix.com/documentation/2.2/manual/api/reference/history/get

python脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
[root@yang python] # catget_items_history.py
#!/usr/bin/env python2.7
#coding=utf-8
import  json
import  urllib2
# based url and required header
url  =  "http://1.1.1.1/zabbix/api_jsonrpc.php"
header  =  { "Content-Type" : "application/json" }
# request json
data  =  json.dumps(
{
    "jsonrpc" : "2.0" ,
    "method" : "history.get" ,
    "params" :{
        "output" : "extend" ,
        "history" : 3 ,
        "itemids" : "25159" ,
        "limit" : 10
    },
    "auth" : "3c0e88885a8cf8af9502b5c850b992bd" # theauth id is what auth script returns, remeber it is string
    "id" : 1 ,
})
# create request object
request  =  urllib2.Request(url,data)
for  key  in  header:
    request.add_header(key,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()
    print  "Number Of Hosts: " len (response[ 'result' ])
    for  host  in  response[ 'result' ]:
        print  host
        #print "Host ID:",host['hostid'],"HostName:",host['name']

python脚本执行结果:

1
2
3
4
5
6
7
8
9
10
11
12
[root@yang python] # pythonget_items_history.py
Number Of Hosts:   10
{u 'itemid' : u '25159' , u 'ns' : u '420722133' ,u 'value' : u '3008' , u 'clock' : u '1410744079' }
{u 'itemid' : u '25159' , u 'ns' : u '480606614' ,u 'value' : u '5720' , u 'clock' : u '1410744139' }
{u 'itemid' : u '25159' , u 'ns' : u '40905600' ,u 'value' : u '6144' , u 'clock' : u '1410744200' }
{u 'itemid' : u '25159' , u 'ns' : u '175337062' ,u 'value' : u '2960' , u 'clock' : u '1410744259' }
{u 'itemid' : u '25159' , u 'ns' : u '202705084' ,u 'value' : u '3032' , u 'clock' : u '1410744319' }
{u 'itemid' : u '25159' , u 'ns' : u '263158421' ,u 'value' : u '2864' , u 'clock' : u '1410744379' }
{u 'itemid' : u '25159' , u 'ns' : u '702285081' ,u 'value' : u '7600' , u 'clock' : u '1410744439' }
{u 'itemid' : u '25159' , u 'ns' : u '231191890' ,u 'value' : u '3864' , u 'clock' : u '1410744499' }
{u 'itemid' : u '25159' , u 'ns' : u '468566742' ,u 'value' : u '3112' , u 'clock' : u '1410744559' }
{u 'itemid' : u '25159' , u 'ns' : u '421679098' ,u 'value' : u '2952' , u 'clock' : u '1410744619' }

curl命令:

1
curl  - - X POST  - 'Content-Type:application/json'  - '{"jsonrpc":"2.0","method":"history.get","params":{"history":3,"itemids":"25154","output":"extend","limit":10},"auth":"11d2b45415d5de6770ce196879dbfcf1","id": 0}'  http: / / 1.1 . 1.1 / zabbix / api_jsonrpc.php

curl命令运行结果:

1
{ "jsonrpc" : "2.0" , "result" :[{ "itemid" : "25154" , "clock" : "1410744134" , "value" : "4840" , "ns" : "375754276" },{ "itemid" : "25154" , "clock" : "1410744314" , "value" : "5408" , "ns" : "839852515" },{ "itemid" : "25154" , "clock" : "1410744374" , "value" : "7040" , "ns" : "964558609" },{ "itemid" : "25154" , "clock" : "1410744554" , "value" : "4072" , "ns" : "943177771" },{ "itemid" : "25154" , "clock" : "1410744614" , "value" : "8696" , "ns" : "995289716" },{ "itemid" : "25154" , "clock" : "1410744674" , "value" : "6144" , "ns" : "992462863" },{ "itemid" : "25154" , "clock" : "1410744734" , "value" : "6472" , "ns" : "152634327" },{ "itemid" : "25154" , "clock" : "1410744794" , "value" : "4312" , "ns" : "479599424" },{ "itemid" : "25154" , "clock" : "1410744854" , "value" : "4456" , "ns" : "263314898" },{ "itemid" : "25154" , "clock" : "1410744914" , "value" : "8656" , "ns" : "840460009" }], "id" : 0 }

 

6.     history.get方法获取单个监控项最后的值

只需把上个脚本中或curl中的limit参数改为1就可。



此时监控项的数据已拿到了,接下来的把它传给前台展示就行了。





     本文转自杨云1028 51CTO博客,原文链接:http://blog.51cto.com/yangrong/1559123,如需转载请自行联系原作者




相关文章
|
4天前
|
缓存 前端开发 API
API接口封装系列
API(Application Programming Interface)接口封装是将系统内部的功能封装成可复用的程序接口并向外部提供,以便其他系统调用和使用这些功能,通过这种方式实现系统之间的通信和协作。下面将介绍API接口封装的一些关键步骤和注意事项。
|
6天前
|
存储 缓存 JavaScript
python实战篇:利用request库打造自己的翻译接口
python实战篇:利用request库打造自己的翻译接口
23 1
python实战篇:利用request库打造自己的翻译接口
|
11天前
|
监控 前端开发 JavaScript
实战篇:商品API接口在跨平台销售中的有效运用与案例解析
随着电子商务的蓬勃发展,企业为了扩大市场覆盖面,经常需要在多个在线平台上展示和销售产品。然而,手工管理多个平台的库存、价格、商品描述等信息既耗时又容易出错。商品API接口在这一背景下显得尤为重要,它能够帮助企业在不同的销售平台之间实现商品信息的高效同步和管理。本文将通过具体的淘宝API接口使用案例,展示如何在跨平台销售中有效利用商品API接口,以及如何通过代码实现数据的统一管理。
|
23天前
|
安全 算法 API
产品经理必备知识——API接口
前言 在古代,我们的传输信息的方式有很多,比如写信、飞鸽传书,以及在战争中使用的烽烟,才有了著名的烽火戏诸侯,但这些方式传输信息的效率终究还是无法满足高速发展的社会需要。如今万物互联的时代,我通过一部手机就可以实现衣食住行的方方面面,比如:在家购物、远程控制家电、自动驾驶等等,背后都离不开我们今天要聊的API接口。
|
23天前
|
数据采集 JSON API
如何实现高效率超简洁的实时数据采集?——Python实战电商数据采集API接口
你是否曾为获取重要数据而感到困扰?是否因为数据封锁而无法获取所需信息?是否因为数据格式混乱而头疼?现在,所有这些问题都可以迎刃而解。让我为大家介绍一款强大的数据采集API接口。
|
26天前
|
安全 API 数据安全/隐私保护
API接口知识小结
应用程序接口API(Application Programming Interface),是提供特定业务输出能力、连接不同系统的一种约定。这里包括外部系统与提供服务的系统(中后台系统)或后台不同系统之间的交互点。包括外部接口、内部接口,内部接口又包括:上层服务与下层服务接口、同级接口。
|
26天前
|
JSON API 数据库
解释如何在 Python 中实现 Web 服务(RESTful API)。
解释如何在 Python 中实现 Web 服务(RESTful API)。
21 0
|
3天前
|
JSON 监控 API
在API接口对接中关键示例问题(1)
在API接口对接中,有几个关键的问题需要注意,以确保接口的稳定性、安全性和易用性。以下是这些问题及部分示例代码的简要概述
|
6天前
|
安全 API 数据安全/隐私保护
验证码邮件API发送邮件的接口有哪些
本文介绍了五种常用的验证码邮件API接口:AokSend、Mailgun、Amazon SES、阿里云邮件推送和腾讯云邮件推送。这些服务提供稳定、快速的邮件发送功能,适用于用户注册、找回密码等场景。开发者可以通过集成相关API,轻松将验证码邮件功能接入到自己的应用程序中。
|
19天前
|
供应链 搜索推荐 BI
深入了解淘宝原数据:获取API接口及其使用场景
在当今数字化的时代,对于电商行业来说,数据具有极大的价值。淘宝作为中国最大的综合电商平台,拥有庞大的商品信息和用户数据。对于开发者和企业来说,淘宝原数据的获取和分析是实现个性化服务和精准营销的基础。本文将介绍如何通过API接口获取淘宝原数据,以及数据的使用场景。

推荐镜像

更多