python批量添加zabbix Screens的两个脚本分享
发布时间 - 2026-01-10 22:33:46 点击率:次前言

在最初搭建公司监控系统的时候,最头疼的是需要把同类项目组的相同图形添加到一个Screens,由于只能一个一个的添加,非常耗时耗经历。
下面分享两个脚本来解决这个头疼的问题。
1.将单个主机的所有图形添加到一个Screens
使用方法
#更改main()函数里的url、username、password #参数一:主机名 #参数二:筛选图名称 python zabbix_screen_host.py 'zabbixserver' 'zabbixserver'
zabbix_screen_host.py脚本内容
#!/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.将同组主机的同一图形添加到一个Screens
使用方法
#更改main()函数里的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脚本内容
#!/usr/bin/env python
import urllib2
import sys
import json
import argparse
#定义通过HTTP方式访问API地址的函数,后面每次请求API的各个方法都会调用这个函数
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接口认证的函数,登录成功会返回一个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
#定义更加主机分组名称获取各个hostid的函数
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的函数
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
#定义创建screen的函数
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不存在则直接创建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已经存在,直接创建screen是不行的,
#要么先使用screen.delete把原来的screen删除掉,然后再创建,
#要么直接使用screen.update更新原来那个screen,
#使用screen.delete会产生新的screenid,
#使用screen.update比较合理一点。
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()
总结
以上就是这篇文章的全部内容了,希望本文的内容的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# python
# python批量运行脚本
# python3实现zabbix告警推送钉钉的示例
# Python 调用 zabbix api的方法示例
# python实现zabbix发送短信脚本
# Python从ZabbixAPI获取信息及实现Zabbix-API 监控的方法
# python实现Zabbix-API监控
# zabbix利用python脚本发送报警邮件的方法
# python自动统计zabbix系统监控覆盖率的示例代码
# 的是
# 有多少
# 不存在
# 然后再
# 这篇文章
# 监控系统
# 是否存在
# 比较合理
# 删除掉
# 最初
# 最头疼
# 有疑问
# host
# selecttype
# columns
# graphid
# value_type
# selectItems
# itemid
# select
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
python中快速进行多个字符替换的方法小结
php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
郑州企业网站制作公司,郑州招聘网站有哪些?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
简单实现Android验证码
免费网站制作appp,免费制作app哪个平台好?
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
javascript读取文本节点方法小结
微信公众帐号开发教程之图文消息全攻略
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
Laravel怎么判断请求类型_Laravel Request isMethod用法
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
网站制作价目表怎么做,珍爱网婚介费用多少?
三星、SK海力士获美批准:可向中国出口芯片制造设备
网站制作免费,什么网站能看正片电影?
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道
JavaScript模板引擎Template.js使用详解
Laravel如何发送系统通知?(Notification渠道示例)
php结合redis实现高并发下的抢购、秒杀功能的实例
制作电商网页,电商供应链怎么做?
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
如何用景安虚拟主机手机版绑定域名建站?
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
如何将凡科建站内容保存为本地文件?
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
如何在阿里云服务器自主搭建网站?
如何基于云服务器快速搭建个人网站?
北京的网站制作公司有哪些,哪个视频网站最好?
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
Laravel如何使用Vite进行前端资源打包?(配置示例)
Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
Laravel集合Collection怎么用_Laravel集合常用函数详解
Laravel如何为API编写文档_Laravel API文档生成与维护方法
详解Android——蓝牙技术 带你实现终端间数据传输
C语言设计一个闪闪的圣诞树
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
EditPlus中的正则表达式 实战(2)
网站图片在线制作软件,怎么在图片上做链接?

