分佈式監控系統Zabbix3.4-釘釘告警配置記錄

 

羣機器人是釘釘羣的高級擴展功能,羣機器人能夠將第三方服務的信息聚合到羣聊中,實現自動化的信息同步。例如:經過聚合GitHub,GitLab等源碼管理服務,實現源碼更新同步;經過聚合Trello,JIRA等項目協調服務,實現項目信息同步。不只如此,羣機器人支持Webhook協議的自定義接入,支持更多可能性. 好比咱們可將Zabbix運維報警提醒經過自定義機器人聚合到釘釘羣中,以實現釘釘告警。下面記錄下Zabbix經過釘釘告警的設置過程:python

一. 釘釘機器人建立
登陸釘釘客戶端,建立一個羣,把須要收到報警信息的人員都拉到這個羣內.而後點擊羣右上角的"羣機器人"->"添加機器人"->"自定義",記錄該機器人的webhook值!web

二. Zabbix設置json

[root@zabbix01 ~]# cat /usr/local/zabbix/etc/zabbix_server.conf|grep AlertScriptsPath
AlertScriptsPath=/usr/local/zabbix/monitor_scripts

登陸到/usr/local/zabbix/monitor_scripts下編寫dingding.py腳本(腳本中包含釘釘機器人的webhook值):
[root@zabbix01 ~]# cd /usr/local/zabbix/monitor_scripts/

[root@zabbix01 monitor_scripts]# cat dingding.py 
#!/usr/bin/env python
#coding:utf-8
#zabbix釘釘報警
import requests,json,sys,os,datetime
webhook="https://oapi.dingtalk.com/robot/send?**********************************************"
user=sys.argv[1]
text=sys.argv[3]
data={
    "msgtype": "text",
    "text": {
        "content": text
    },
    "at": {
        "atMobiles": [
            user
        ],
        "isAtAll": False
    }
}
headers = {'Content-Type': 'application/json'}
x=requests.post(url=webhook,data=json.dumps(data),headers=headers)
if os.path.exists("/usr/local/zabbix/logs/dingding.log"):
    f=open("/usr/local/zabbix/logs/dingding.log","a+")
else:
    f=open("/usr/local/zabbix/logs/dingding.log","w+")
f.write("\n"+"--"*30)
if x.json()["errcode"] == 0:
    f.write("\n"+str(datetime.datetime.now())+"    "+str(user)+"    "+"發送成功"+"\n"+str(text))
    f.close()
else:
    f.write("\n"+str(datetime.datetime.now()) + "    " + str(user) + "    " + "發送失敗" + "\n" + str(text))
    f.close()


建立上面腳本中的日誌路徑:
[root@zabbix01 monitor_scripts]# touch /usr/local/zabbix/logs/dingding.log
[root@zabbix01 monitor_scripts]# chown zabbix.zabbix dingding.py 
[root@zabbix01 monitor_scripts]# chmod 755 dingding.py 
[root@zabbix01 monitor_scripts]# chown zabbix.zabbix /usr/local/zabbix/logs/dingding.log 


手動測試腳本發信是否正常:
這個條文檔記錄的測試信息,忽略
[root@zabbix01 monitor_scripts]# ./dingding.py test 13611027803 "這個條測試信息,忽略"          

===========================================================
注意:該腳本要求至少python2.6.6版本,且具備requests模塊.

不然會報錯:
Traceback (most recent call last):
  File "./dingding.py", line 4, in <module>
    import requests,json,sys,os,datetime
ImportError: No module named requests


解決辦法:
[root@zabbix01 monitor_scripts]# yum install python-pip
[root@zabbix01 monitor_scripts]# pip -v
[root@zabbix01 monitor_scripts]# pip install requests 

===========================================================

釘釘上收到的測試信息以下:api

三. Zabbix監控界面設置bash

1) 建立報警媒介.  三個參數分別是:ALERT.SENDTO      ALERT.SUBJECT      ALERT.MESSAGEapp

2) 用戶添加報警媒介
收件人是釘釘上的手機號碼.這裏使用Admin管理員用戶,在Admin用戶的"報警媒介"裏添加收件人信息
特別注意:這裏只須要添加釘釘羣裏的任何一個成員的手機號碼便可,即添加一個收件人,這樣在機器人羣裏成員都能看到告警信息.
若是添加多個收件人,則機器人羣裏就會發送多個告警信息,一個收件人發一條信息. 運維

3) 添加動做
動做裏的報警信息和恢復信息都發送給Admin用戶.post

操做
默認接收人:{TRIGGER.STATUS}: {TRIGGER.NAME}
默認信息:
告警主機:{HOST.NAME}
主機IP: {HOST.IP}
告警時間:{EVENT.DATE} {EVENT.TIME} 
告警等級:{TRIGGER.SEVERITY} 
告警信息:{TRIGGER.NAME}
問題詳情:{ITEM.NAME}:{ITEM.VALUE}
當前狀態: {TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID: {EVENT.ID}

恢復操做(確認操做也是同樣):
默認接收人:{TRIGGER.STATUS}: {TRIGGER.NAME}
默認信息:
告警主機:{HOST.NAME}
主機IP: {HOST.IP}
告警時間:{EVENT.DATE} {EVENT.TIME} 
告警等級:{TRIGGER.SEVERITY} 
告警信息:{TRIGGER.NAME}
問題詳情:{ITEM.NAME}:{ITEM.VALUE}
當前狀態: {TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID: {EVENT.ID}

而後進行測試,好比關閉一臺被監控機器的10050端口,過一下子,查看下釘釘上的報警信息,以下:測試

還能夠查看dingding.log日誌,看看告警信息發送狀況:url

相關文章
相關標籤/搜索