在以前的文章裏,經過Zabbix對主機的磁盤、CPU以及內存進行了監控,並在首頁Dashboard裏建立了監控圖形,可是隻有當咱們登陸到Zabbix後才能看到監控到的問題(Problem),所以在本篇文章裏,將利用觸發器(Trigger),以及媒介(Media)等配置項,實現當觸發器觸發時,經過不一樣媒介,如:郵件、釘釘,發送動做(Action),實現實時通知告警功能。javascript
因爲使用到腳本告警媒介,本文中經過調用Python腳本觸發告警,所以須要在Zabbix Server主機上安裝pip以及相關模塊。(這裏Python使用Centos7自帶的Python2.7.5)html
安裝pipjava
# yum install -y epel-release # yum install -y python-pip
安裝requests模塊python
# pip install requests
Zabbix默認自帶了2種報警媒介類型(Media Type),電子郵件以及短信,咱們將修改電子郵件類型配置,並新建腳本類型和Webhook類型。但願經過腳本、Webhook告警媒介發送釘釘消息。web
注:Webhook告警媒介是Zabbix 4.4的新特性shell
修改電子郵件告警媒介json
點擊【管理】-【報警媒介類型】-【Email】vim
修改Email配置,我這裏用的是Outlook郵箱,具體SMTP服務器能夠參考Outlook官網 SMTP設置。使用其餘郵箱也能夠去對應官網查詢SMTP配置。api
測試發送郵箱,點擊【測試】服務器
輸入收件人郵箱
收到郵件
新增腳本告警媒介
新建Python腳本告警媒介,用戶釘釘告警
點擊【建立媒體類型】
進行配置
配置項 | 值 |
---|---|
* 名稱 | Python腳本 |
類型 | 腳本 |
* 腳本名稱 | pythonScript.py |
腳本參數(參數1) | {ALERT.MESSAGE} |
腳本參數(參數2) | {ALERT.SENDTO} |
腳本參數(參數3) | {ALERT.SUBJECT} |
接下來新建Python腳本,Zabbix Server配置文件中能夠配置告警腳本路徑,默認爲 /usr/lib/zabbix/alertscripts
# 查看告警腳本路徑 # cat zabbix_server.conf | grep AlertScriptsPath
編寫告警腳本
# cd /usr/lib/zabbix/alertscripts # vim pythonScript.py
腳本內容
#!/usr/bin/env python #coding:utf-8 import requests,json,sys,os,datetime # 釘釘機器人地址 webhook="https://oapi.dingtalk.com/robot/send?access_token=your_dingding_robot_access_token" # 對應{ALERT.SENDTO}, Zabbix告警媒介配置界面第2個參數 user=sys.argv[2] # 對應{ALERT.MESSAGE}, Zabbix告警媒介配置界面第1個參數 text=sys.argv[1] 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)
給腳本可執行權限
# chmod uo+x /usr/lib/zabbix/alertscripts/pythonScript.py
測試腳本
釘釘收到消息
新增Webhook告警媒介
配置項 | 值 |
---|---|
* 名稱 | Webhook |
類型 | Webhook |
參數: (名稱) | 值 |
user | {ALERT.SENDTO} |
subject | {ALERT.SUBJECT} |
message | {ALERT.MESSAGE} |
腳本:
try { Zabbix.Log(4, 'params= '+value); params = JSON.parse(value); req = new CurlHttpRequest(); data = {}; result = {}; req.AddHeader('Content-Type: application/json'); data.msgtype = "text"; // 對應 message參數 data.text = {"content" : params.message}; // 對應 user參數 data.at = {"atMobiles": [params.user], "isAtAll": "false"}; // 釘釘機器人 resp = req.Post('https://oapi.dingtalk.com/robot/send?access_token=your_access_token', JSON.stringify(data) ); } catch (error) { result = {}; } return JSON.stringify(result);
測試Webhook
須要將新增的告警媒介添加給用戶
點擊【用戶】-【告警媒介】
將上述步驟添加的告警媒介(Python腳本、Webhoob、Email),進行添加(收件人根據告警媒介類型填寫郵箱或手機號),嚴重性也根據須要勾選。
完成上述配置完成後,須要建立動做(Action),將觸發器(Trigger)和告警媒介(Media Type)進行關聯,一旦觸發器觸發,那麼Zabbix會執行動做,再去執行告警媒介。
添加動做
點擊【配置】-【動做】-【建立動做】
配置【動做】相關信息
配置項 | 值 |
---|---|
* 名稱 | 告警動做 |
新的觸發條件 | 【觸發器】【等於】【Template Disk Free Size: 磁盤剩餘空間觸發器】 |
操做步驟以下圖:
羣組選擇 ->Linux servers
主機選擇 -> Template Disk Free Size 模板(上一篇文章中定義的模板)
勾選觸發器 -> 磁盤剩餘空間觸發器 (上一篇文章中建立的觸發器)
勾選後點擊【選擇】
配置【操做】相關信息
點擊【操做】
先配置如下信息
配置項 | 值 |
---|---|
* 默認操做步驟持續時間 | 1h(保持默認) |
默認標題 | 告警: {EVENT.NAME} |
消息內容 | 【磁盤空間不足告警】 告警事件: {EVENT.DATE} {EVENT.TIME} 告警問題: {EVENT.NAME} 告警主機: {HOST.IP} {HOST.NAME} 告警級別: {EVENT.SEVERITY} 磁盤剩餘:{ITEM.VALUE} |
上述配置表格【默認標題】和【消息內容】值中形如{EVENT.NAME}的內容是Zabbix中的宏(Marco),宏是一個變量,例如 {HOST.IP} 表示告警主機的IP地址,Zabbix自帶的宏能夠參考Zabbix 4.4自帶宏
繼續配置操做
【操做類型】選擇發送消息,【發送到用戶】添加Admin
【僅送到】根據須要選擇以前配置的告警媒介,本文選擇Email和Python腳本(這裏只能單選或全選,因此須要先選擇一個,所以須要屢次添加)
添加完成後點擊【添加】
向被監控主機拷貝或下載大文件,使其磁盤剩餘空間低於觸發器監控閾值,等待觸發器觸發問題,查看儀表盤、郵件等。
儀表盤
釘釘
郵件