zabbix自动停用与开启agent
我们在升级环境时遇到了一个问题,那就是zabbix会自动发送邮件给领导,此时领导心里会嘎嘣一下,为了给领导营造一个良好的环境,减少不必要的告警邮件,减少嘎嘣次数,于是在升级之前,取消zabbix监控的agent,当升级完之后再恢复过去。
一、简介
zabbix提供了API接口,可满足基本使用需求,具体参考:zabbix API
有了API接口,我们就可以做到:
自动执行常规任务
将zabbix与第三方软件集成
创建新的应用程序以使用zabbix
zabbix API 是基于web API的,使用的是JSON-RPC2.0协议,客户端与API之间的请求使用的是JSON格式进行编码。
使用远程http请求调用api,需要向 api_jsonrpc.php 位于前端目录中的文件发送HTTP POST请求,url是http://zabbixserverIP/zabbix/api_jsonrpc.php。
请求的头部信息 必须是以下值之一:
application/json-rpc, application/json 或 application/jsonrequest
json中主要的对象有:
jsonrpc - API使用的JSON-RPC协议的版本; Zabbix API实现的JSON-RPC版本是2.0;
method - 被调用的API方法名;
params - 将被传递给API方法的参数;
id - 请求的任意标识符;
auth -用户认证令牌; 因为我们还没有一个,它的设置null。
二、思路整理
登陆zabbix,获取token
利用token获取agent的id
利用已获取的id和token调整agent的连接状态
三、具体实现
#!/usr/bin/python
import sys
import json
import requests if( len(sys.argv) < 2 ): #需强调传入3个以上的参数
print("[Usage] $1 is 0/1(0:open 1:off) ; $2 $3.... is agent name. ")
sys.exit(1) class Error(Exception): #定义自定义错误
def __init__(self,*args):
self.args = args def login(user,passwd,url,header): #登陆函数获取token
# return token
data = {
"jsonrpc": "2.0" ,
"method": "user.login" ,
"params": {
"user": user ,
"password": passwd
} ,
"id": 1 ,
}
r = requests.post ( url=url , headers=header , data=json.dumps ( data ) )
if ( r.status_code == 200 ):
return r.json ()['result']
else:
raise Error("return status code is not eq 200. login failed!") def gethostid(hostname,token,url,header): #获取id
#get dict { hostid , status}
data = {
"jsonrpc": "2.0" ,
"method": "host.get" ,
"params": {
"output": ['status'] ,
"filter": {
"host": [
hostname
]
}
} ,
"auth": token ,
"id": 1
}
r = requests.post ( url=url , headers=header , data=json.dumps ( data ) )
if( r.status_code == 200 ):
if( r.json()['result'] != [] ): #判断获取到的信息不为“[]”证明是有数据的
return r.json ()['result'][0]
else:
print(" %s hostname is wrong!!" % hostname)
exit(1)
else:
raise Error("return status code is not eq 200. gethostid failed!") def changestatus(hostid,token,url,header,onoroff): #修改agent的连接状态
# 0:open ; 1:off
data = {
"jsonrpc": "2.0" ,
"method": "host.update" ,
"params": {
"hostid": hostid ,
"status": onoroff
} ,
"auth": token ,
"id": 1
}
r = requests.post ( url=url , headers=header , data=json.dumps ( data ) )
r.close()
if ( r.status_code == 200 ):
return r.json ()['result']["hostids"]
else:
raise Error("return status code is not eq 200. changestatus failed!") if __name__ == '__main__':
allhostname = [ i for i in sys.argv[2:]]
onoroff = int(sys.argv[1])
#allhostname = ["agent1","agent2"]
#onoroff = 0
msg = {0:"on",1:"off"} #设定开关,0为开启,1为关闭
url = 'http://zabbixserverip/zabbix/api_jsonrpc.php' #后缀必须是 zabbix/api_jsonrpc.php
user = 'bill'
passwd = '123456'
header = {"Content-Type": "application/json"} try:
for hostname in allhostname:
token = login ( user , passwd , url , header )
dict = gethostid(hostname,token,url,header)
print(dict)
hostid = dict["hostid"]
status = dict["status"]
print("defore the change,hostname: %s hostid:%s status:%s [ %s ] " % (hostname,hostid,status,msg[onoroff]))
if( onoroff != int(status)):
res=changestatus(hostid,token,url,header,onoroff)
dict2 = gethostid ( hostname , token , url , header )
hostid2 = dict2["hostid"]
status2 = dict2["status"]
print("after the change status: %s [ %s ]" % (status2,msg[onoroff]) )
if (status != status2 ):
print(" %s [ %s ] successful!" % (hostname,msg[onoroff]))
else:
print(" %s [ %s ] failed!" % (hostname , msg[onoroff]) )
else:
print("current %s is %s ,No change." % (hostname,msg[onoroff])) except Exception as e:
print(e)
将文件移动到ubuntu上,文件名是zabbixagent_onoff.py,可以跟多个主机名,主机名host name,不是visible name


再将其加入jenkins等持续集成工具中,就可实现开关agent了
zabbix自动停用与开启agent的更多相关文章
- zabbix自动发现与自动注册、自定义监控
一.自动发现与自动注册在上面的介绍中,我们演示了手动添加一台主机的方法,虽然简单,但是当要添加的主机非常多时,也将变得非常繁琐,那么有没有一种方法,可以实现主机的批量添加呢,这样就会极大的提高运维效率 ...
- Zabbix自动发现与自动注册.
一, 自动发现与自动注册 自动发现? 当场景中出现要添加很多台主机的时候,一台台添加难免太过于繁琐,zabbix提供自动注册,自动发现,可以实现主机的批量添加, zabbix的发现包括三种类型: # ...
- 转 zabbix 自动发现和 zabbix自定义用户key与参数User parameters
########31 https://www.cnblogs.com/yjt1993/p/10883345.html 1.概念 在配置Iterms的过程中,有时候需要对类似的Iterms进行添加,这些 ...
- 网站集群架构(LVS负载均衡、Nginx代理缓存、Nginx动静分离、Rsync+Inotify全网备份、Zabbix自动注册全网监控)--技术流ken
前言 最近做了一个不大不小的项目,现就删繁就简单独拿出来web集群这一块写一篇博客.数据库集群请参考<MySQL集群架构篇:MHA+MySQL-PROXY+LVS实现MySQL集群架构高可用/高 ...
- zabbix 自动发现 相关
zabbix自动发现,是zabbix精髓所在. 生产中,一台服务器上可能会存在多个监控实例,比如:A服务器2个,B服务器4个, C服务器1个.单单靠套模板来完成监控,做法那太糟糕了.比如小明有100台 ...
- zabbix自动发现与自动注册及SNMP监控
自动发现与自动注册 自动发现:zabbix Server主动发现所有客户端,然后将客户端登记自己的小本本上,缺点zabbix server压力山大(网段大,客户端多),时间消耗多. 自动注册:zabb ...
- Zabbix自动发现之fping
原文发表于cu:2016-06-21 Zabbix自动发现功能从配置流程上比较简单:Discovery与Action. 在做Zabbix的自动发现验证时,使用"ICMP ping" ...
- zabbix自动发现监控mysql
一. 数据库给只读权限 1.1 grant usage on *.* to 'zabbix'@'127.0.0.1' identified by 'zabbix'; flush privileges; ...
- zabbix自动发现主机(转)
zabbix自动发现主机 2018年06月15日 18:02:52 loyal-Wang 阅读数:817更多 个人分类: zabbix 版权声明:本文为博主原创文章,转载请注明出处. https: ...
随机推荐
- springBoot 利用Idea打包部署
springBoot 打包部署 1 项目如图: 2 依赖打包插件 3 打包操作 4 运行项目:
- Java中String对象的存储位置(学习笔记)
首先,String是final修饰的.immutable对象,它以一个个字符的方式存储在字符数组中.其次,String类型创建对象有两种方式:①通过字面量赋值:会先去常量池中查找是否存在相同的字符串, ...
- 每隔15s异步刷新手机页面
前台异步js发请求代码: <script type="text/javascript"> var lightArr; var lightHistoryArr; /* 每 ...
- Objective-C Classes Are also Objects
https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/ProgrammingWithObjectiveC ...
- LeetCode 953. Verifying an Alien Dictionary
原题链接在这里:https://leetcode.com/problems/verifying-an-alien-dictionary/ 题目: In an alien language, surpr ...
- 灰度图像--图像分割 Prewitt算子
学习DIP第45天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对此表示很不 ...
- 「NOIP2016」换教室
传送门 Description 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 $ 2n $ 节课程安排在 $ n $ 个时间段上.在第 $ i ...
- MySql的执行计划
一.什么是数据库执行计划: MySQL执行计划是sql语句经过查询优化器后,查询优化器会根据用户的sql语句所包含的字段和内容数量等统计信息,选择出一个执行效率最优(MySQL系统认为最优)的执行计划 ...
- eclipse debug调试 class文件 Source not found.
1.情景展示 明明有class文件,为什么提示没有? 2.原因分析 这是eclipse与myeclipse的不同之处,myeclipse会自动加载运行时所需的的class文件,而eclipse则需 ...
- Linux kill、kill-15、kill-9区别
进程状态转换图 kill和kill -9,两个命令在linux中都有杀死进程的效果,然而两命令的执行过程却大有不同,在程序中如果用错了,可能会造成莫名其妙的现象. 执行kill(不加 -* 默认kil ...