Python 操作Zabbix API 获取ERROR级别告警信息并打印
1.需求:有一个语音合成播报项目,要实时获取zabbix的ERROR级别以上告警信息,将该信息合成语音播报出去。(合成语音及播报已经完成)
2.现实:整理zabbix告警级别,将不太重要的告警放到ERROR级别以下,将重点信息设置为ERROR级别,然后通过zabbbix api获取。
3.简单实现:
#!/usr/bin/env python
#coding:utf-8
import json
import urllib2
from urllib2 import URLError
import sys
zabbix_addresses=['http://www.baidu.com/zabbix,Admin,Admin]
class ZabbixTools:
def __init__(self,address,username,password): self.address = address
self.username = username
self.password = password self.url = '%s/api_jsonrpc.php' % self.address
self.header = {"Content-Type":"application/json"} def user_login(self):
data = json.dumps({
"jsonrpc": "2.0",
"method": "user.login",
"params": {
"user": self.username,
"password": self.password
},
"id": 0
}) request = urllib2.Request(self.url, data)
for key in self.header:
request.add_header(key, self.header[key]) try:
result = urllib2.urlopen(request)
except URLError as e:
print "Auth Failed, please Check your name and password:", e.code
else:
response = json.loads(result.read())
result.close()
#print response['result']
self.authID = response['result']
return self.authID def trigger_get(self):
data = json.dumps({
"jsonrpc":"2.0",
"method":"trigger.get",
"params": {
"output": [
"triggerid",
"description",
"priority"
],
"filter": {
"value": 1
},
"sortfield": "priority",
"sortorder": "DESC",
"min_severity": 4,
"skipDependent": 1,
"monitored": 1,
"active": 1,
"expandDescription": 1,
"selectHosts": ['host'],
"selectGroups": ['name'],
"only_true": 1
},
"auth": self.user_login(),
"id":1
}) request = urllib2.Request(self.url, data)
for key in self.header:
request.add_header(key, self.header[key]) try:
result = urllib2.urlopen(request)
except URLError as e:
print "Error as ", e
else:
response = json.loads(result.read())
result.close()
issues = response['result']
content = ''
if issues:
for line in issues:
#content = content + "%s:%s:%s\r\n" % (line['groups'],line['hosts'],line['description'])
content = content + "%s\r\n" % (line['description'])
# print line
return content if __name__ == "__main__":
for zabbix_addres in zabbix_addresses:
address,username,password = zabbix_addres.split(',')
z = ZabbixTools(address=address, username=username, password=password)
content = z.trigger_get()
print content
#!/usr/bin/env python
#coding:utf-8
import json
import urllib2
from urllib2 import URLError
import sys
zabbix_addresses=['http://www.aliyun.com/zabbix,Admin,Admin]
class ZabbixTools:
def __init__(self,address,username,password): self.address = address
self.username = username
self.password = password self.url = '%s/api_jsonrpc.php' % self.address
self.header = {"Content-Type":"application/json"} def user_login(self):
data = json.dumps({
"jsonrpc": "2.0",
"method": "user.login",
"params": {
"user": self.username,
"password": self.password
},
"id": 0
}) request = urllib2.Request(self.url, data)
for key in self.header:
request.add_header(key, self.header[key]) try:
result = urllib2.urlopen(request)
except URLError as e:
print "Auth Failed, please Check your name and password:", e.code
else:
response = json.loads(result.read())
result.close()
#print response['result']
self.authID = response['result']
return self.authID def trigger_get(self):
data = json.dumps({
"jsonrpc":"2.0",
"method":"trigger.get",
"params": {
"output": [
"triggerid",
"description",
"priority"
],
"filter": {
"value": 1
},
"sortfield": "priority",
"sortorder": "DESC",
"min_severity": 4,
"skipDependent": 1,
"monitored": 1,
"active": 1,
"expandDescription": 1,
"selectHosts": ['host'],
"selectGroups": ['name'],
"only_true": 1
},
"auth": self.user_login(),
"id":1
}) request = urllib2.Request(self.url, data)
for key in self.header:
request.add_header(key, self.header[key]) try:
result = urllib2.urlopen(request)
except URLError as e:
print "Error as ", e
else:
response = json.loads(result.read())
result.close()
issues = response['result']
content = ''
if issues:
for line in issues:
#content = content + "%s:%s:%s\r\n" % (line['groups'],line['hosts'],line['description'])
content = content + "%s\r\n" % (line['description'])
# print line
return content if __name__ == "__main__":
for zabbix_addres in zabbix_addresses:
address,username,password = zabbix_addres.split(',')
z = ZabbixTools(address=address, username=username, password=password)
content = z.trigger_get()
print conten
Python 操作Zabbix API 获取ERROR级别告警信息并打印的更多相关文章
- Python 操作Sonqube API 获取检测结果并打印
		
1.需求:每次Sonqube检查完毕后,需要登陆才能看到结果无法通过Jenkins发布后直接看到bug 及漏洞数量. 2.demo:发布后,可以将该项目的检测结果简单打印出来显示,后面还可以集成钉钉发 ...
 - 关于python调用zabbix api接口
		
因公司业务需要,引进了自动化运维,所用到的监控平台为zbbix3.2,最近正在学习python,计划使用python调用zabbix api接口去做些事情,如生成报表,我想最基本的是要取得zabbix ...
 - PHP通过ZABBIX API获取主机信息 VS 直接从数据库获取主机信息
		
最近项目需要获取linux主机的一些信息,如CPU使用率,内存使用情况等.由于我们本身就装了zabbix系统,所以我只用知道如何获取信息即可,总结有两种方法可以获取. 一.通过ZABBIX API获取 ...
 - python 调用zabbix api接口实现主机的增删改查
		
python程序调用zabbix系统的api接口实现对zabbix_server端主机的增删改查,使用相关功能时候,需要打开脚本中的相关函数. 函数说明: zabbixtools() 调用zabbi ...
 - Zabbix中获取各用户告警媒介分钟级统计
		
任务内容: 获取Zabbix各用户告警媒介分钟级统计,形成趋势图,便于观察各用户在每分钟收到的告警数量,在后续处理中,可以根据用户在某时间段内(例如3分钟内)收到的邮件总数,来判断是否有告警洪水的现象 ...
 - python 调用zabbix api实现查询主机信息,输出所有主机ip
		
之前发现搜索出来的主机调用zabbix api信息都不是那么明确,后来通过zabbix官方文档,查到想要的api信息,随后写一篇自己这次项目中用到的api. #!/usr/bin/env python ...
 - Python通过Zabbix API获得数据
		
Zabbix API查询:https://www.zabbix.com/documentation/2.0/manual/appendix/api/api import json,urllib2 fr ...
 - 使用Python调用Zabbix API
		
Zabbix API官方文档: https://www.zabbix.com/documentation/4.0/zh/manual/api 1.向 api_jsonrpc.php 发送HTTP_PO ...
 - PHP通过Zabbix API获取服务器监控信息
		
开源监控系统Zabbix提供了丰富的API,供第三方系统调用. 基本步骤如下: 1.获取合法认证:连接对应Zabbix URL,并提供用户名和密码,HTTP方法为"POST",HT ...
 
随机推荐
- 在Jetty中部署Jenkins遇到的问题
			
1. Jetty 9.0.3 启动时的错误: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 [root@kvm-guest jetty-9.0.3]# java -jar star ...
 - 虚拟机中Linux环境下使用Squid部署代理缓存服务(及透明传输)
			
小知识: 正确的使用Squid服务程序部署代理缓存服务可以有效提升访问静态资源的效率,降低原服务器的负载. 不仅如此,还为读者们添加了对指定IP地址.网页关键词.网址与文件后缀的ACL访问限制功能的实 ...
 - jdk 7&8 new features
			
7 Diamond Operator(菱形操作符) You can omitted the type declaration of the right when working with Generi ...
 - C++ 用 new 生成一个动态二维数组
			
//Microsoft Visual Studio 2015 Enterprise //变长二维数组 #include <iostream> #include<iomanip> ...
 - Visual Studio 2019 离线安装方法
			
1. 网址 1.1 阅读官方离线安装教程 离线安装官网 仔细阅读离线安装官网,差不多就能学会如何下载. 1.2 工作负荷和组件 ID 进入这个网址,Visual Studio 工作负荷和组件 ID,单 ...
 - C++基础(静态数据成员和静态成员函数)
			
[简介] 1.静态数据成员在类中声明,在源文件中定义并初始化: 2.静态成员函数没有this指针,只能访问静态数据成员: 3.调用静态成员函数:(1)对象.(2)直接调用: 4.静态成员函数的地址可用 ...
 - PAT(A) 1144 The Missing Number(C)统计
			
题目链接:1144 The Missing Number (20 point(s)) Description Given N integers, you are supposed to find th ...
 - 算术 HDU - 6715 (莫比乌斯反演)
			
大意: 给定$n,m$, 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^m\mu(lcm(i,j))$ 首先有$\mu(lcm(i,j))=\mu(i)\mu(j)\m ...
 - 使用MD5加密字符串
			
一.概念: MD5码以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值. 二 ...
 - C#-Parallel
			
using System; using System.Collections.Concurrent; using System.Collections.Generic; using System.Li ...