zabbix摸索之API篇
zabbix API的好处就不讲了(懒癌发作,不想罗列)搜索github上这方面的资源,还真是不少,pyzabbix是其中比较不错的一个,封装了requests/json包,这让自己写脚本更轻松了。
pyzabbix给了很多例子来说明如何做查询,你可以根据此例子和zabbix官方提供的API关键字段来做自己的查询。
摘个其中的例子:
from pyzabbix import ZabbixAPI
zapi = ZabbixAPI("http://zabbixserver.example.com")
zapi.login("zabbix user", "zabbix pass")
print("Connected to Zabbix API Version %s" % zapi.api_version())
for h in zapi.host.get(output="extend"):
print(h['hostid']) "extend" 是必须的参数,这个也是zabbix api必须的,参看这里(我这里看的是3.0的版本,后面也是一样,可以根据自己安装的zabbix版本切换)。
那么我们来参照这个例子来写一个,查询所有的视图的名称。
首先去这里把 API的"Method reference"展开,找到"screen"这一栏。
http://s3.运维网.com/wyfs02/M02/8B/3B/wKioL1hHulyB7oS_AAB0ZB0u4Is162.png-wh_500x0-wm_3-wmp_4-s_2671656026.png
我们要用的方法就是 screen.get,点击进去,可以看到request参数和方法:
{
"jsonrpc": "2.0",
"method": "screen.get",
"params": {
"output": "extend",
"selectScreenItems": "extend",
"selectUsers": "extend",
"selectUserGroups": "extend",
"screenids": "26"
},
"auth": "038e1d7b1735c6a5436ee9eae095879e",
"id": 1} 我们要用到的就是"parmas"这一段。
# 登录就不讲了,看例子。这里是查询所有用户创建的screen
for s in zapi.screen.get(output="extend", selectScreenItems="extend"):
# 打印出screen的名称
print(s['name']) so easy。
接下来我们来看看screen相关的操作,get方法很简单,我们来说说create。看看官方给的例子:
{
"jsonrpc": "2.0",
"method": "screen.create",
"params": {
"name": "Graphs",
"hsize": 3,
"vsize": 2,
"screenitems": [
{
"resourcetype": 0,
"resourceid": "612",
"rowspan": 0,
"colspan": 0,
"x": 0,
"y": 0
}
]
},
"auth": "038e1d7b1735c6a5436ee9eae095879e",
"id": 1} 说实话看到resourceid的时候我蛋疼了,这个resourceid是个什么鬼,经过一番shell进入MySQL库区搜的时候发现是在graphs这个表的第一列。读到这里,熟悉screen添加操作的童鞋想必已经知道,resourceid 在添加graph到screen里的时候才用的上。说明什么呢?如果你想利用API添加一个screen,只需这样写就好
zapi.screen.create(name=SCREEN_NAME,hsize=2,vsize=2,screenitems=[]) 就这么简单(可怜我当时是在操作线上的zabbix,都不怎么敢随便的去创建一个screen去测试,还紧张兮兮的写了半天代码来测试)
页:
[1]