欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 調(diào)用 zabbix api的方法示例

 更新時(shí)間:2019年01月06日 14:09:58   作者:J4ck0r  
這篇文章主要介紹了Python 調(diào)用 zabbix api的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前提準(zhǔn)備:

1.使用python requests模塊

2.了解json

3.zabbix api的具體調(diào)用建議先瀏覽一下官網(wǎng)

先上代碼:

import requests,json
#
#url一定要正確,IP地址換成自己zabbix服務(wù)器的
zbx_url = "http://192.168.60.130:3080/zabbix/api_jsonrpc.php"

#在post請(qǐng)求頭部必須要有 'Content-Type': 'application/json-rpc'
headers = {'Content-Type': 'application/json-rpc'}

#傳遞json 數(shù)據(jù)到api;登錄
login = {
  "jsonrpc": "2.0",
  "method": "user.login",
  "params": {
    "user": "Admin",
    "password": "zabbix"
  },
  "id": 1
}
#首次登陸不用在json字段中寫 auth,否則會(huì)有相關(guān)的報(bào)錯(cuò)

#將數(shù)據(jù)發(fā)送到api
ret = requests.post(zbx_url, data=json.dumps(login), headers=headers)

#對(duì)結(jié)果進(jìn)行序列化
ret = ret.json()
auth = ret['result']

#獲取問題主機(jī)json
data = {
  "jsonrpc": "2.0",
  "method":"trigger.get",
  "params": {
    # output表示輸出結(jié)果包含參數(shù)有哪些
    "output": [
      "triggerid",
      "description",
      "status",
      "value",
      "priority",
      "lastchange",
      "recovery_mode",
      "hosts",
      "state",
    ],
    "selectHosts": "hosts", # 需包含主機(jī)ID信息,以便于根據(jù)主機(jī)ID查詢主機(jī)信息
    "selectItems":"items",
    "filter": {
      # 篩選條件
       "value": 1,#value值為1表示有問題
       "status": 0#status為0表示已啟用的trigger
    },
  },
  "auth":auth,#這里的auth就是登錄后獲取的
  'id':'1'#這個(gè)id可以隨意
}

#將查詢數(shù)據(jù)發(fā)送到zabbix-server
ret = requests.post(zbx_url,data=json.dumps(data),headers=headers)

respone_result = ret.json()['result']#對(duì)結(jié)果進(jìn)行json序列化

print(respone_result)

下面簡單介紹一下上訴代碼:

要調(diào)用zabbix api獲取數(shù)據(jù),首先要獲得auth這一串字符用戶后續(xù)的內(nèi)容獲取,auth可以看做是一種你與zabbix-server之間的"暗號(hào)";

登錄的json內(nèi)容之所以這樣寫是zabbix官方規(guī)定的,json字符串里面千萬不能使用tab鍵。

login = {
  "jsonrpc": "2.0",
  "method": "user.login",
  "params": {
    "user": "Admin",     #根據(jù)自己的情況填
    "password": "zabbix"   #根據(jù)自己的條件填寫
  },
  "id": 1
}

獲取問題主機(jī)的json字符串建議先瀏覽一下官網(wǎng)的說明,要強(qiáng)調(diào)的是output和filter這兩個(gè)key,output就是zabbix api返回來的內(nèi)容,filter相當(dāng)于是過濾條件:

"filter": {
      # 篩選條件
       "value": 1,       #value值為1表示有問題
       "status": 0       #status為0表示已啟用的trigger
    },

上訴代碼表示 value=1 and status=0,是一種與關(guān)系,很像查數(shù)據(jù)庫表時(shí)候的過濾操作。

強(qiáng)烈建議先大概瀏覽一下官網(wǎng)文檔

PS:Python通過Zabbix API獲得數(shù)據(jù)的方法

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 地址,用戶名,密碼,這里修改為自己實(shí)際的參數(shù)
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
#用戶認(rèn)證信息的部分,最終的目的是得到一個(gè)SESSIONID
#這里是生成一個(gè)json格式的數(shù)據(jù),用戶名和密碼
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)
#對(duì)于出錯(cuò)新的處理
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是否在返回的數(shù)據(jù)中
if 'result' in response:
  auth_code=response['result']
else:
  print response['error']['data']
                                                                                          
# request json
#用得到的SESSIONID去通過驗(yàn)證,獲取主機(jī)的信息(用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()                                                                                    
    #將所有的主機(jī)信息顯示出來
    for r in response['result']:
    #  print r['hostid'],r['host']
      host_list.append(r['hostid'])
    #顯示主機(jī)的個(gè)數(shù)
    print "Number Of Hosts: ", len(host_list)

  

  #返回所有hostid==10251的主機(jī),并只查詢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獲取相應(yīng)的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

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例

    Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例

    這篇文章主要介紹了Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用,結(jié)合實(shí)例形式分析了Python數(shù)據(jù)結(jié)構(gòu)中圖的定義與遍歷算法相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • Python使用numpy模塊創(chuàng)建數(shù)組操作示例

    Python使用numpy模塊創(chuàng)建數(shù)組操作示例

    這篇文章主要介紹了Python使用numpy模塊創(chuàng)建數(shù)組操作,結(jié)合實(shí)例形式分析了Python使用numpy模塊實(shí)現(xiàn)數(shù)組的創(chuàng)建、賦值、修改、打印等相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2018-06-06
  • 解析Python3中的Import

    解析Python3中的Import

    本文通過示例代碼帶領(lǐng)大家一起學(xué)習(xí)Python3中的Import知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-10-10
  • Python實(shí)現(xiàn)字典排序、按照list中字典的某個(gè)key排序的方法示例

    Python實(shí)現(xiàn)字典排序、按照list中字典的某個(gè)key排序的方法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)字典排序、按照list中字典的某個(gè)key排序的方法,涉及Python字典與列表排序相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12
  • Python的Bottle框架中實(shí)現(xiàn)最基本的get和post的方法的教程

    Python的Bottle框架中實(shí)現(xiàn)最基本的get和post的方法的教程

    這篇文章主要介紹了Python的Bottle框架中實(shí)現(xiàn)最基本的get和post的方法的教程,Bottle框架在Python開發(fā)者中的人氣很高,需要的朋友可以參考下
    2015-04-04
  • Django 對(duì)IP訪問頻率進(jìn)行限制的例子

    Django 對(duì)IP訪問頻率進(jìn)行限制的例子

    今天小編就為大家分享一篇Django 對(duì)IP訪問頻率進(jìn)行限制的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • python遞歸計(jì)算N!的方法

    python遞歸計(jì)算N!的方法

    這篇文章主要介紹了python遞歸計(jì)算N!的方法,涉及Python遞歸計(jì)算階乘的技巧,非常簡單實(shí)用,需要的朋友可以參考下
    2015-05-05
  • 關(guān)于python環(huán)境變量如何配置

    關(guān)于python環(huán)境變量如何配置

    這篇文章主要介紹了關(guān)于python環(huán)境變量如何配置,當(dāng)我們?cè)谧约弘娔X上同時(shí)安裝了python2.x和python3.x版本的解釋器的時(shí)候,就需要對(duì)環(huán)境變量的配置進(jìn)行一定的修改,需要的朋友可以參考下
    2023-04-04
  • python安裝mysql的依賴包mysql-python操作

    python安裝mysql的依賴包mysql-python操作

    這篇文章主要介紹了python安裝mysql的依賴包mysql-python操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • python爬蟲之request模塊深入講解

    python爬蟲之request模塊深入講解

    requests是python實(shí)現(xiàn)的簡單易用的HTTP庫,使用起來比urllib簡潔很多,下面這篇文章主要給大家介紹了關(guān)于python爬蟲之request模塊的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03

最新評(píng)論