今天继续给大家介绍Linux运维相关知识,本文主要内容是zabbix微信报警实战。
首先,我们要进行企业微信的设置。创建一个企业微信,并在该企业微信下创建部门,并且向部门中加入几个用户,如下所示:
接下来,我们需要在应用管理页面上创建一个应用程序,并且将可见范围设置为我们的部门,如下所示:
完成创建后,我们可以查看应用程序的Agentd号和Secret号,如下所示:
至此,我们需要记下小程序的Agentd号、Secret号以及部门号在,这些信息会在后面的配置中用到。
接下来,我们需要在zabbix server端进行配置,写一个微信报警的脚本。
微信报警脚本如下所示:
#!/usr/bin/python2.7
#_*_coding:utf-8 _*_
#auther:muquan
import requests,sys,json
import urllib3
urllib3.disable_warnings()
reload(sys)
sys.setdefaultencoding('utf-8')
def GetTokenFromServer(Corpid,Secret):
Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
Data = {
"corpid":Corpid,
"corpsecret":Secret
}
r = requests.get(url=Url,params=Data,verify=False)
print(r.json())
if r.json()['errcode'] != 0:
return False
else:
Token = r.json()['access_token']
file = open('/tmp/zabbix_wechat_config.json', 'w')
file.write(r.text)
file.close()
return Token
def SendMessage(User,Agentid,Subject,Content):
try:
file = open('/tmp/zabbix_wechat_config.json', 'r')
Token = json.load(file)['access_token']
file.close()
except:
Token = GetTokenFromServer(Corpid, Secret)
n = 0
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
Data = {
#"touser": User, # 企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
#"totag": Tagid, # 企业号中的标签id,群发使用(推荐)
"toparty": 2, # 企业号中的部门id,群发时使用。
"msgtype": "text", # 消息类型。
"agentid": 1000002, # 企业号中的应用id。
"text": {
"content": Subject + '\n' + Content
},
"safe": "0"
}
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
while r.json()['errcode'] != 0 and n < 4:
n+=1
Token = GetTokenFromServer(Corpid, Secret)
if Token:
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
print(r.json())
return r.json()
if __name__ == '__main__':
User = sys.argv[1] # zabbix传过来的第一个参数
Subject = str(sys.argv[2]) # zabbix传过来的第二个参数
Content = str(sys.argv[3]) # zabbix传过来的第三个参数
Corpid = "" # CorpID是企业号的标识
Secret = "" # Secret是管理组凭证密钥
#Tagid = "1" # 通讯录标签ID
Agentid = "1000001" # 应用ID
#Partyid = "1" # 部门ID
Status = SendMessage(User,Agentid,Subject,Content)
print Status
Corpid、Secret、toparty和agentid分别表示企业号、密钥、部门ID和应用程序ID,我们需要根据实际情况进行填写。此外,由于这个脚本由Python编写,因此,我们将该脚本命名为wechat_alert.py,并将其放入/usr/loca/zabbix/alertscripts/目录下,并授予其可执行权限。同时,由于该脚本调用了request模块,因此,我们还需要安装request,执行命令:
pip install request
执行命令过程如下所示:
完成脚本编写后,我们还需要设置zabbix服务端查找脚本的路径,打开zabbix server端配置文件/usr/local/zabbix/etc/zabbix_server.conf,在其中找到AlertScriptsPath参数,将其修改为我们存放脚本的位置/usr/local/zabbix/scriptsalert/。
完成配置后,即可重启zabbix server服务。
接下来,我们来进行zabbix web端的配置。我们的目的是实现zabbix server端使用我们的自定义脚本,最终实现微信告警。关于动作和触发器的配置在
zabbix详解(七)——zabbix邮件报警设置一文中已经介绍过了,在这里就不过多赘述了,在这里仅说明一下报警媒介的添加。
进入报警媒介添加页面后,我们将类型选择为脚本,然后填写好报警媒介名称和脚本名称。脚本名称必须与我们自定义脚本的文件名相同。我们的脚本需要添加三个脚本参数,如下所示:
{ALERT.SENDTO}
{ALERT.SUBJECT}
{ALERT.MESSAGE}
在完成上述配置后,我们来进行配置效果的检验,触发zabbix客户端失联报警,结果如下所示:
从上图可以看出,我们的zabbix能够正常调用我们的微信报警脚本,实现微信报警,zabbix微信报警实战成功!
原创不易,转载请说明出处:https://blog.csdn.net/weixin_40228200