詳解如何調(diào)用zabbix API獲取主機(jī)
前言
zabbix 作為企業(yè)級(jí)的系統(tǒng)和網(wǎng)絡(luò)監(jiān)控方案,對(duì)于中小型公司來(lái)說(shuō)基本可以很好的滿足對(duì)機(jī)器的監(jiān)控需求,因?yàn)槠洳渴鸱奖悖僮骱?jiǎn)單深受現(xiàn)在各個(gè)互聯(lián)網(wǎng)公司喜愛,所以現(xiàn)在基本的互聯(lián)網(wǎng)公司監(jiān)控用zabbix的非常多,當(dāng)你安裝好zabbix服務(wù)端 后,如果啟動(dòng)自動(dòng)注冊(cè)功能,在所有客戶機(jī)安裝后會(huì)自動(dòng)在zabbix平臺(tái)上被監(jiān)控到,但這里有個(gè)問(wèn)題,如果你機(jī)器數(shù)量非常少,如果還能數(shù)的過(guò)來(lái)那基本沒(méi)什么問(wèn)題,但如果你機(jī)器上千臺(tái)了,這個(gè)時(shí)候那些機(jī)器被監(jiān)控中,那些沒(méi)被監(jiān)控,查起來(lái)就沒(méi)那么方便了,所以日常運(yùn)維中經(jīng)常發(fā)現(xiàn)的問(wèn)題就是某臺(tái)機(jī)器故障了但沒(méi)報(bào)警,經(jīng)查發(fā)現(xiàn)這臺(tái)機(jī)器zabbix客戶端因?yàn)槟撤N原因?qū)е聸](méi)有被服務(wù)端監(jiān)控到,像這種問(wèn)題怎么辦呢?其實(shí)最簡(jiǎn)單的方案就是從zabbix里獲取所有被監(jiān)控的服務(wù)器列表,然后跟運(yùn)維資產(chǎn)數(shù)據(jù)庫(kù)去比對(duì),如果數(shù)量一致,那說(shuō)明監(jiān)控沒(méi)漏機(jī)器,如果比對(duì)不上,就把對(duì)不上的IP發(fā)出來(lái)再報(bào)個(gè)警就可以了,整體邏輯就是這樣。
Zabbix API是在1.8版本中開始引進(jìn)并且已經(jīng)被廣泛應(yīng)用。所有的Zabbix移動(dòng)客戶端都是基于API,甚至原生的WEB前端部分也是建立在它之上。Zabbix API 中間件使得架構(gòu)更加模塊化也避免直接對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作。它允許你通過(guò)JSON RPC協(xié)議來(lái)創(chuàng)建、更新和獲取Zabbix對(duì)象并且做任何你喜歡的操作【當(dāng)然前提是你擁有認(rèn)證賬戶】。
Zabbix API提供兩項(xiàng)主要功能:
- 遠(yuǎn)程管理Zabbix配置
- 遠(yuǎn)程檢索配置和歷史數(shù)據(jù)
我們今天用zabbix api獲取被監(jiān)控的所有機(jī)器列表
代碼如下
#!/usr/bin/evn python import requests import json ZABIX_ROOT = "http://10.0.1.29/zabbix" url = ZABIX_ROOT + "/api_jsonrpc.php" # user.login payload = { "jsonrpc" : "2.0", "method" : "user.login", "params": { "user": "Admin", "password":"", }, "auth" : None, "id" : 0, } headers = { "content-type": "application/json", } req = requests.post(url, json=payload, headers=headers) auth = req.json() # host.get payload = { "jsonrpc" : "2.0", "method" : "host.get", "params": { "output": [ "hostid", "name"], }, "auth" : auth["result"], "id" : 2, } res2 = requests.post(url, data=json.dumps(payload), headers=headers) res2 = res2.json() for host in res2["result"]: with open("host.txt", "a+") as f: f.write(host["name"] + "\n)
腳本一共分二部分,第一部分是用戶登錄,登錄后然后獲取主機(jī)列表,最后寫到一個(gè)文件里去,所以腳本運(yùn)行的結(jié)果是生成一個(gè)所有被監(jiān)控的IP列表,通過(guò)這個(gè)列表你就可以去跟你的資產(chǎn)庫(kù)信息去對(duì)比了,還有這個(gè)腳本用的requests,所以看起來(lái)要清爽很多,代碼比較簡(jiǎn)單,就是二個(gè)post就不做太多解釋了。
總結(jié)
以上就是關(guān)于調(diào)用zabbix API獲取主機(jī)的全部?jī)?nèi)容了,喜歡的小伙伴可以在此基礎(chǔ)上修改成合適自己業(yè)務(wù)的腳本,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章:
1. 使用Zabbix 5.4.3監(jiān)控IPMI的方法2. Zabbix監(jiān)控方案-官方最新4.4版本【推薦】3. Zabbix實(shí)現(xiàn)監(jiān)控多個(gè)mysql過(guò)程解析4. 詳解Zabbix安裝部署實(shí)踐5. centos7.9安裝zabbix5.0.14及配置過(guò)程6. Zabbix3.4監(jiān)控mongodb數(shù)據(jù)庫(kù)狀態(tài)的方法7. ubuntu系統(tǒng)下部署zabbix服務(wù)器監(jiān)控的方法教程8. zabbix監(jiān)控sqlserver的過(guò)程詳解9. 基于docker安裝zabbix的詳細(xì)教程10. zabbix執(zhí)行遠(yuǎn)程主機(jī)的腳本或指令詳解
