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"这一栏。

zabbix摸索之API篇_第1张图片

        我们要用的方法就是 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去测试,还紧张兮兮的写了半天代码来测试)