python批量添加zabbix Screens的兩個(gè)腳本分享
前言
在最初搭建公司監(jiān)控系統(tǒng)的時(shí)候,最頭疼的是需要把同類項(xiàng)目組的相同圖形添加到一個(gè)Screens,由于只能一個(gè)一個(gè)的添加,非常耗時(shí)耗經(jīng)歷。
下面分享兩個(gè)腳本來(lái)解決這個(gè)頭疼的問(wèn)題。
1.將單個(gè)主機(jī)的所有圖形添加到一個(gè)Screens
使用方法
#更改main()函數(shù)里的url、username、password #參數(shù)一:主機(jī)名 #參數(shù)二:篩選圖名稱 python zabbix_screen_host.py 'zabbixserver' 'zabbixserver'
zabbix_screen_host.py腳本內(nèi)容
#!/usr/bin/env python #zabbix_screen_host.py import urllib2 import json import argparse def authenticate(url, username, password): values = {'jsonrpc': '2.0', 'method': 'user.login', 'params': { 'user': username, 'password': password }, 'id': '0' } data = json.dumps(values) req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'}) response = urllib2.urlopen(req, data) output = json.loads(response.read()) try: message = output['result'] except: message = output['error']['data'] print message quit() return output['result'] def getGraph(hostname, url, auth, graphtype, dynamic, columns): if (graphtype == 0): selecttype = ['graphid'] select = 'selectGraphs' if (graphtype == 1): selecttype = ['itemid', 'value_type'] select = 'selectItems' values = {'jsonrpc': '2.0', 'method': 'host.get', 'params': { select: selecttype, 'output': ['hostid', 'host'], 'searchByAny': 1, 'filter': { 'host': hostname } }, 'auth': auth, 'id': '2' } data = json.dumps(values) req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'}) response = urllib2.urlopen(req, data) host_get = response.read() output = json.loads(host_get) # print json.dumps(output) graphs = [] if (graphtype == 0): for i in output['result'][0]['graphs']: graphs.append(i['graphid']) if (graphtype == 1): for i in output['result'][0]['items']: if int(i['value_type']) in (0, 3): graphs.append(i['itemid']) graph_list = [] x = 0 y = 0 for graph in graphs: graph_list.append({ "resourcetype": graphtype, "resourceid": graph, "width": "500", "height": "100", "x": str(x), "y": str(y), "colspan": "1", "rowspan": "1", "elements": "0", "valign": "0", "halign": "0", "style": "0", "url": "", "dynamic": str(dynamic) }) x += 1 if x == columns: x = 0 y += 1 return graph_list def screenCreate(url, auth, screen_name, graphids, columns): # print graphids if len(graphids) % columns == 0: vsize = len(graphids) / columns else: vsize = (len(graphids) / columns) + 1 values = {"jsonrpc": "2.0", "method": "screen.create", "params": [{ "name": screen_name, "hsize": columns, "vsize": vsize, "screenitems": [] }], "auth": auth, "id": 2 } for i in graphids: values['params'][0]['screenitems'].append(i) data = json.dumps(values) req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'}) response = urllib2.urlopen(req, data) host_get = response.read() output = json.loads(host_get) try: message = output['result'] except: message = output['error']['data'] print json.dumps(message) def main(): url = 'http://zabbixip/zabbix/api_jsonrpc.php' username = "***" password = "***" parser = argparse.ArgumentParser(description='Create Zabbix screen from all of a host Items or Graphs.') parser.add_argument('hostname', metavar='H', type=str, help='Zabbix Host to create screen from') parser.add_argument('screenname', metavar='N', type=str, help='Screen name in Zabbix. Put quotes around it if you want spaces in the name.') parser.add_argument('-c', dest='columns', type=int, default=3, help='number of columns in the screen (default: 3)') parser.add_argument('-d', dest='dynamic', action='store_true', help='enable for dynamic screen items (default: disabled)') parser.add_argument('-t', dest='screentype', action='store_true', help='set to 1 if you want item simple graphs created (default: 0, regular graphs)') args = parser.parse_args() hostname = args.hostname screen_name = args.screenname columns = args.columns dynamic = (1 if args.dynamic else 0) screentype = (1 if args.screentype else 0) auth = authenticate(url, username, password) graphids = getGraph(hostname, url, auth, screentype, dynamic, columns) print "Screen Name: " + screen_name print "Total Number of Graphs: " + str(len(graphids)) screenCreate(url, auth, screen_name, graphids, columns) if __name__ == '__main__': main()
2.將同組主機(jī)的同一圖形添加到一個(gè)Screens
使用方法
#更改main()函數(shù)里的url、username、password #-g :組名稱 #-G:圖形名稱 #-n :篩選(screen)圖名稱 #-c : 一行有多少圖形 python zabbix_screen_group.py -g 'zabbix' -G 'icmp-ping' -n 'zabbix-icmp-ping' -c 2
zabbix_screen_group.py腳本內(nèi)容
#!/usr/bin/env python import urllib2 import sys import json import argparse #定義通過(guò)HTTP方式訪問(wèn)API地址的函數(shù),后面每次請(qǐng)求API的各個(gè)方法都會(huì)調(diào)用這個(gè)函數(shù) def requestJson(url,values): data = json.dumps(values) req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'}) response = urllib2.urlopen(req, data) output = json.loads(response.read()) # print output try: message = output['result'] except: message = output['error']['data'] print message quit() return output['result'] #API接口認(rèn)證的函數(shù),登錄成功會(huì)返回一個(gè)Token def authenticate(url, username, password): values = {'jsonrpc': '2.0', 'method': 'user.login', 'params': { 'user': username, 'password': password }, 'id': '0' } idvalue = requestJson(url,values) return idvalue #定義更加主機(jī)分組名稱獲取各個(gè)hostid的函數(shù) def getHosts(groupname,url,auth): host_list = [] values = {'jsonrpc': '2.0', 'method': 'hostgroup.get', 'params': { 'output': 'extend', 'filter': { 'name': groupname }, 'selectHosts' : ['hostid','host'], }, 'auth': auth, 'id': '2' } output = requestJson(url,values) for host in output[0]['hosts']: host_list.append(host['hostid']) return host_list #定義獲取graphid的函數(shù) def getGraphs(host_list,name_list, url, auth, columns, graphtype=0 ,dynamic=0): if (graphtype == 0): selecttype = ['graphid'] select = 'selectGraphs' if (graphtype == 1): selecttype = ['itemid', 'value_type'] select = 'selectItems' values=({'jsonrpc' : '2.0', 'method' : 'graph.get', 'params' : { 'output' : ['graphid','name'], select : [selecttype,'name'], 'hostids' : host_list, 'sortfield' : 'name', 'filter' : { 'name' : name_list, }, }, 'auth' : auth, 'id' : 3 }) output = requestJson(url,values) bb = sorted(output,key = lambda x:x['graphid']) graphs = [] if (graphtype == 0): for i in bb: print i graphs.append(i['graphid']) if (graphtype == 1): for i in bb: if int(i['value_type']) in (0, 3): graphs.append(i['itemid']) graph_list = [] x = 0 y = 0 for graph in graphs: print "x is " + str(x) print "y is " + str(y) graph_list.append({ "resourcetype": graphtype, "resourceid": graph, "width": "500", "height": "100", "x": str(x), "y": str(y), "colspan": "1", "rowspan": "1", "elements": "0", "valign": "0", "halign": "0", "style": "0", "url": "", "dynamic": str(dynamic) }) x += 1 # print type(x) # print type(columns) if x == int(columns): x = 0 y += 1 # print graph_list return graph_list #定義創(chuàng)建screen的函數(shù) def screenCreate(url, auth, screen_name, graphids, columns): columns = int(columns) if len(graphids) % columns == 0: vsize = len(graphids) / columns else: vsize = (len(graphids) / columns) + 1 #先使用screen.get判斷給定的screen name是否存在 values0 = { "jsonrpc" : "2.0", "method" : "screen.get", "params" : { "output" : "extend", "filter" : { "name" : screen_name, } }, "auth" : auth, "id" : 2 } values = { "jsonrpc": "2.0", "method": "screen.create", "params": { "name": screen_name, "hsize": columns, "vsize": vsize, "screenitems": [] }, "auth": auth, "id": 2 } output0 = requestJson(url,values0) print output0 #如果給定的screen name不存在則直接創(chuàng)建screen if output0 == []: print "The Given Screen Name Not Exists" print "Creating Screen %s" %screen_name for i in graphids: values['params']['screenitems'].append(i) output = requestJson(url,values) else: #如果給定的screen name已經(jīng)存在,直接創(chuàng)建screen是不行的, #要么先使用screen.delete把原來(lái)的screen刪除掉,然后再創(chuàng)建, #要么直接使用screen.update更新原來(lái)那個(gè)screen, #使用screen.delete會(huì)產(chǎn)生新的screenid, #使用screen.update比較合理一點(diǎn)。 print "The Given Screen Name Already Exists" update_screenid=output0[0]["screenid"] print update_screenid print "Updating Screen Name %s Screen ID %s" %(screen_name,update_screenid) values1 = { "jsonrpc" : "2.0", "method" : "screen.update", "params" : { "screenid" : update_screenid, "screenitems": [] }, "auth" : auth, "id" : 2 } output1 = requestJson(url,values1) print output1 print "Updating Screen Name %s" %screen_name for i in graphids: values1['params']['screenitems'].append(i) output = requestJson(url,values1) def main(): url = 'http://zabbixip/zabbix/api_jsonrpc.php' username = '****' password = '****' auth = authenticate(url, username, password) host_list = getHosts(groupname,url,auth) print host_list graph_ids = getGraphs(host_list,graphname, url, auth, columns) screenCreate(url, auth, screenname, graph_ids, columns) if __name__ == '__main__': parser = argparse.ArgumentParser(description='Create Zabbix screen from all of a host Items or Graphs.') parser.add_argument('-G', dest='graphname', nargs='+',metavar=('grah name'), help='Zabbix Host Graph to create screen from') parser.add_argument('-H', dest='hostname', nargs='+',metavar=('10.19.111.145'), help='Zabbix Host to create screen from') parser.add_argument('-g', dest='groupname', nargs='+',metavar=('linux server'), help='Zabbix Group to create screen from') parser.add_argument('-n', dest='screenname', type=str, help='Screen name in Zabbix. Put quotes around it if you want spaces in the name.') parser.add_argument('-c', dest='columns', type=int, help='number of columns in the screen') args = parser.parse_args() print args hostname = args.hostname groupname = args.groupname screenname = args.screenname columns = args.columns graphname = args.graphname if columns is None: columns = len(graphname) # print columns main()
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
使用C語(yǔ)言來(lái)擴(kuò)展Python程序和Zope服務(wù)器的教程
這篇文章主要介紹了使用C語(yǔ)言來(lái)擴(kuò)展Python程序和Zope服務(wù)器的教程,本文來(lái)自于IBM官方網(wǎng)站技術(shù)文檔,需要的朋友可以參考下2015-04-04opencv+python實(shí)現(xiàn)圖像矯正
這篇文章主要為大家詳細(xì)介紹了opencv+python實(shí)現(xiàn)圖像矯正,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08Python OpenCV實(shí)現(xiàn)攝像頭人臉識(shí)別功能
這篇文章主要介紹了Python OpenCV實(shí)現(xiàn)攝像頭人臉識(shí)別,使用Python 3和OpenCV進(jìn)行攝像頭人臉識(shí)別的基本步驟,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07Python Opencv提取圖片中某種顏色組成的圖形的方法
這篇文章主要介紹了Python Opencv提取圖片中某種顏色組成的圖形的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09python實(shí)現(xiàn)ModBusTCP協(xié)議的client功能
Modbus TCP 是一種基于 TCP/IP 協(xié)議棧的 Modbus 通信協(xié)議,它用于在工業(yè)自動(dòng)化系統(tǒng)中進(jìn)行設(shè)備之間的通信,只要通過(guò)pymodbus或pyModbusTCP任意模塊就可以實(shí)現(xiàn),本文采用pymodbus,感興趣的朋友跟隨小編一起看看吧2023-10-10python使用Streamlit庫(kù)制作Web可視化頁(yè)面
一談到Web頁(yè)面,可能大家首先想到就是HTML,CSS或JavaScript。 本次小F就給大家介紹一下如何用Python制作一個(gè)數(shù)據(jù)可視化網(wǎng)頁(yè),使用到的是Streamlit庫(kù)。輕松的將一個(gè)Excel數(shù)據(jù)文件轉(zhuǎn)換為一個(gè)Web頁(yè)面,提供給所有人在線查看。2021-05-05Python讀取系統(tǒng)文件夾內(nèi)所有文件并統(tǒng)計(jì)數(shù)量的方法
今天小編就為大家分享一篇Python讀取系統(tǒng)文件夾內(nèi)所有文件并統(tǒng)計(jì)數(shù)量的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10