本文配置步骤:php
https://work.weixin.qq.com/api/doc#10013html
第一个要记录的值:部门ID:1python
选择企业应用golang
选择建立应用json
自定义填c#
建立应用后退出,点击刚才建立的应用进入api
记录下这两个值:AgentId、Secret服务器
而后选择企业微信
记录值:CorpIdapp
能够使用企业微信的API接口测试一下
http://work.weixin.qq.com/api/devtools/devtool.php
返回值以下即为OK,能够写脚本引用
告警脚本:(此脚本针对部门ID发送,添加后台应用选择哪些人可见而后哪些人就能够收到告警了,若是新增一个应用,就copy这个代码到另外一个脚本修改corpid就能够了)
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import urllib,urllib2,json
import sys
reload(sys)
sys.setdefaultencoding( "utf-8" )
class WeChat(object):
__token_id = ''
# init attribute
def __init__(self,url):
self.__url = url.rstrip('/')
self.__corpid = 'xxx' #这里修改企业id
self.__secret = 'xxx-xxx' #这里修改告警应用secretid
# Get TokenID
def authID(self):
params = {'corpid':self.__corpid, 'corpsecret':self.__secret}
data = urllib.urlencode(params)
content = self.getToken(data)
try:
self.__token_id = content['access_token']
print content['access_token']
except KeyError:
raise KeyError
# Establish a connection
def getToken(self,data,url_prefix='/'):
url = self.__url + url_prefix + 'gettoken?'
try:
response = urllib2.Request(url + data)
except KeyError:
raise KeyError
result = urllib2.urlopen(response)
content = json.loads(result.read())
return content
# Get sendmessage url
def postData(self,data,url_prefix='/'):
url = self.__url + url_prefix + 'message/send?access_token=%s' % self.__token_id
request = urllib2.Request(url,data)
try:
result = urllib2.urlopen(request)
except urllib2.HTTPError as e:
if hasattr(e,'reason'):
print 'reason',e.reason
elif hasattr(e,'code'):
print 'code',e.code
return 0
else:
content = json.loads(result.read())
result.close()
return content
# send message
def sendMessage(self,touser,message):
self.authID()
data = json.dumps({
'totag':touser,
'msgtype':"text",
'agentid':"2", ##这里修改告警应用id
'text':{
'content':message
},
'safe':"0"
},ensure_ascii=False)
response = self.postData(data)
print response
if __name__ == '__main__':
a = WeChat('https://qyapi.weixin.qq.com/cgi-bin')
a.sendMessage(sys.argv[1],sys.argv[3])
测试发送:python zabbix_weixin.py "1" "test" "test"
测试没有问题,开始配置zabbix
选择建立用户
添加报警媒介
权限能够看状况分配,我这本身用能够给大一点
选择报警媒介类型
建立媒体类型 别忘点“更新”
选择配置-动做
建立动做
默认接收人:
告警 {TRIGGER.NAME} 时间: {EVENT.DATE} {EVENT.TIME} 内容: 1. {ITEM.NAME1} ({HOST.NAME1}:{ITEM.KEY1}): {ITEM.VALUE1}
Recovery operations
默认接收人:
恢复 {TRIGGER.NAME} 时间: {EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME} 内容: 1. {ITEM.NAME1} ({HOST.NAME1}:{ITEM.KEY1}): {ITEM.VALUE1}
将zabbix_server的agent关闭看是否报警,而后再启动看是否有恢复通知
钉钉告警同样,下载千思网 的钉钉告警脚本。拉钉钉群聊,添加机器人记录地址
https://www.qiansw.com/golang-zabbix-alter-to-dingding.html
告警xml内容
<?xml version="1.0" encoding="UTF-8" ?><root> <from>{HOSTNAME1}</from> <time>{EVENT.DATE} {EVENT.TIME}</time> <name>{TRIGGER.NAME}</name> <key>{TRIGGER.KEY1}</key> <value>{ITEM.VALUE}</value> <now>{ITEM.LASTVALUE}</now> <id>{EVENT.ID}</id> <ip>{HOST.IP}</ip> <url>这里是点击报警消息能够访问的连接地址</url> <age>{EVENT.AGE}</age> <status>{EVENT.STATUS}</status> <acknowledgement> {EVENT.ACK.STATUS} </acknowledgement><acknowledgementhistory> {EVENT.ACK.HISTORY}</acknowledgementhistory></root>
恢复内容
{TRIGGER.STATUS}: {TRIGGER.NAME} <?xml version="1.0" encoding="UTF-8" ?><root> <from>{HOSTNAME1}</from> <time>{EVENT.DATE} {EVENT.TIME}</time> <name>{TRIGGER.NAME}</name> <key>{TRIGGER.KEY1}</key> <value>{ITEM.VALUE}</value> <now>{ITEM.LASTVALUE}</now> <id>{EVENT.ID}</id> <ip>{HOST.IP}</ip> <color>FF4A934A</color> <url>这里的url会替换报警媒介的url</url> <age>{EVENT.AGE}</age> <recoveryTime>{EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME}</recoveryTime> <status>{EVENT.RECOVERY.STATUS}</status> </root>
其余调用钉钉机器人告警
#conding=utf-8 ## -- coding:UTF-8 -- import requests import json import time,datetime import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart def sendmail(subject,msg,toaddrs,fromaddr,smtpaddr,password): mail_msg = MIMEMultipart() if not isinstance(subject,unicode): subject = unicode(subject, 'utf-8') mail_msg['Subject'] = subject mail_msg['From'] = fromaddr mail_msg['To'] = ','.join(toaddrs) mail_msg.attach(MIMEText(msg, 'html', 'utf-8')) try: s = smtplib.SMTP() s.connect(smtpaddr) #链接smtp服务器 s.login(fromaddr,password) #登陆邮箱 s.sendmail(fromaddr, toaddrs, mail_msg.as_string()) #发送邮件 s.quit() except Exception,e: print "Error: unable to send email" def msg(text): json_text = { "msgtype": "text", "at": { "atMobiles": [ "11111" ], "isAtAll": False }, "text": { "content": text } } print(requests.post(api_url, json.dumps(json_text), headers=headers).content) if __name__ == '__main__': ''' https://oapi.dingtalk.com/robot/send?access_token=xxx ''' #钉钉发送 #token = "xxx" token = "xxx" date = datetime.datetime.now().strftime('%Y-%m') text = "xxx" % date headers = {'Content-Type': 'application/json;charset=utf-8'} api_url = "https://oapi.dingtalk.com/robot/send?access_token=%s" % token msg(text)