一、钉钉配置
1、添加钉钉机器人
关于钉钉的注册我这里不再过多介绍。
2、选择添加机器人
3、选择自定义机器人
4、创建完成之后记住webhook,后面用于发送消息
二、Zabbix配置
1、创建脚本
# vim /usr/local/zabbix/alertscripts/dingding_text.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#!/usr/bin/python # -*- coding: utf-8 -*- import requests
import json
import sys
import os
headers = { 'Content-Type' : 'application/json;charset=utf-8' }
api_url = "https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxxxxxxxx"
def msg(text):
json_text = {
"msgtype" : "text" ,
"text" : {
"content" : text
},
"at" : {
"atMobiles" : [
"1881***1223"
],
"isAtAll" : False
}
}
print requests.post(api_url,json.dumps(json_text),headers = headers).content
if __name__ = = '__main__' :
text = sys.argv[ 1 ]
msg(text)
|
1
2
|
#赋予执行权限 chmod +x /usr/local/zabbix/alertscripts/dingding_text .py
|
2、创建Media types
因为钉钉的text主要是发送卡片消息,所以我这里参数只输出的message,如果想要传递user,比如手机号,可以添加这个参数,然后脚本稍微修改一下即可。
3、给用户添加Media
3、创建Actions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
服务器:{HOST.NAME}发生: {TRIGGER.NAME}故障! { 告警主机:{HOST.NAME} 告警地址:{HOST.IP} 监控项目:{ITEM.NAME} 监控取值:{ITEM.LASTVALUE} 告警等级:{TRIGGER.SEVERITY} 当前状态:{TRIGGER.STATUS} 告警信息:{TRIGGER.NAME} 告警时间:{EVENT.DATE} {EVENT.TIME} 事件ID:{EVENT.ID} } 服务器:{HOST.NAME}: {TRIGGER.NAME}已恢复! { 告警主机:{HOST.NAME} 告警地址:{HOST.IP} 监控项目:{ITEM.NAME} 监控取值:{ITEM.LASTVALUE} 告警等级:{TRIGGER.SEVERITY} 当前状态:{TRIGGER.STATUS} 告警信息:{TRIGGER.NAME} 告警时间:{EVENT.DATE} {EVENT.TIME} 恢复时间:{EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME} 持续时间:{EVENT.AGE} 事件ID:{EVENT.ID} } 服务器:{HOST.NAME}: 报警确认 { 确认人:{USER.FULLNAME} 时间:{ACK.DATE} {ACK.TIME} 确认信息如下: "{ACK.MESSAGE}" 问题服务器IP:{HOSTNAME1} 问题ID:{EVENT.ID} 当前的问题是: {TRIGGER.NAME} } |
三、效果展示
本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1978792,如需转载请自行联系原作者