Zabbix監控客戶端及實現郵件、微信報警

博文大綱:
一、安裝Zabbix agent端
二、登錄web界面添加agent主機
三、Zabbix監控MySQL數據庫
四、配置郵件報警
五、配置企業微信報警

注:本文是基於博文:部署zabbix監控服務器 的環境。

這篇博文用到的所有軟件都可以在這個鏈接獲得:Zabbix 軟件包

一、安裝Zabbix agent端

這裏我啓動了一臺IP爲192.168.20.3的服務器,用於充當agent端。

[root@agent ~]# tar zxf zabbix-3.2.1.tar.gz -C /usr/src/
[root@agent ~]# cd /usr/src/zabbix-3.2.1/
[root@agent zabbix-3.2.1]# ./configure --prefix=/usr/local/zabbix --enable-agent && make && make install
[root@agent zabbix-3.2.1]# useradd zabbix -M -s /sbin/nologin 
#修改啓動腳本
[root@agent zabbix-3.2.1]# cp misc/init.d/fedora/core/zabbix_agentd /etc/init.d/
[root@agent ~]# sed -i 's/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g' /etc/init.d/zabbix_agentd 
[root@agent ~]# sed -i 's/PIDFILE=\/tmp\/$BINARY_NAME.pid/PIDFILE=$BASEDIR\/logs\/$BINARY_NAME.pid/g' /etc/init.d/zabbix_agentd 
[root@agent ~]# chmod +x /etc/init.d/zabbix_agentd
#修改配置文件
[root@agent ~]# cd /usr/local/zabbix/etc/
[root@agent etc]# sed -i 's/# PidFile=\/tmp\/zabbix_agentd.pid/PidFile=\/usr\/local\/zabbix\/logs\/zabbix_agentd.pid/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/LogFile=\/tmp\/zabbix_agentd.log/LogFile=\/usr\/local\/zabbix\/logs\/zabbix_agentd.log/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/Server=127.0.0.1/Server=192.168.20.2/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/# ListenPort=10050/ListenPort=10050/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/ServerActive=127.0.0.1/ServerActive=192.168.20.2/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/Hostname=Zabbix server/Hostname=192.168.20.3/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/# Timeout=3/Timeout=15/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/# Include=\/usr\/local\/etc\/zabbix_agentd.conf.d\//Include=\/usr\/local\/zabbix\/etc\/zabbix_agentd.conf.d\//g' zabbix_agentd.conf
[root@agent etc]# egrep -v '^$|^#' zabbix_agentd.conf   #確認更改的配置文件
PidFile=/usr/local/zabbix/logs/zabbix_agentd.pid
LogFile=/usr/local/zabbix/logs/zabbix_agentd.log
Server=192.168.20.2
ListenPort=10050
ServerActive=192.168.20.2
Hostname=192.168.20.3
Timeout=15
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/
[root@agent etc]# mkdir /usr/local/zabbix/logs
[root@agent etc]# chown -R zabbix:zabbix /usr/local/zabbix/
[root@agent etc]# /etc/init.d/zabbix_agentd start   #啓動agent

二、登錄web界面添加agent主機

登錄到Zabbix server端進行以下操作,以便監控剛剛配置的agent端。

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警
Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

三、Zabbix監控MySQL數據庫

以下操作在新配置的agent端進行(自行部署MySQL數據庫,在博文開頭的博文鏈接中有腳本安裝MySQL數據庫的方法)。

#複製Zabbix提供的MySQL監控腳本
[root@agent etc]# cd /usr/src/zabbix-3.2.1/conf/zabbix_agentd/
[root@agent zabbix_agentd]# cp userparameter_mysql.conf /usr/local/zabbix/etc/zabbix_agentd.conf.d/
[root@agent zabbix_agentd]# cd /usr/local/zabbix/etc/
#編寫文件,存放登錄數據庫的賬號
[root@agent etc]# cat > .my.cnf << EOF
> [client]
> host=192.168.20.3
> user=test
> password=123.com
> socket=/usr/local/mysql/mysql.sock
> EOF
#修改MySQL監控腳本
[root@agent ~]# cd /usr/local/zabbix/etc/zabbix_agentd.conf.d
[root@agent zabbix_agentd.conf.d]# sed -i 's/mysql -N/\/usr\/local\/bin\/mysql -N/g' userparameter_mysql.conf 
[root@agent zabbix_agentd.conf.d]# sed -i 's/mysql -V/\/usr\/local\/bin\/mysql -V/g' userparameter_mysql.conf 
[root@agent zabbix_agentd.conf.d]# sed -i 's/mysqladmin ping/\/usr\/local\/bin\/mysqladmin ping/g' userparameter_mysql.conf 
[root@agent zabbix_agentd.conf.d]# sed -i 's/HOME=\/var\/lib\/zabbix/HOME=\/usr\/local\/zabbix\/etc\//g' userparameter_mysql.conf 
#重啓agent服務,使更改生效
[root@agent zabbix_agentd.conf.d]# /etc/init.d/zabbix_agentd restart
#授權數據庫用戶
[root@agent ~]# mysql -uroot -p123   
mysql> grant all on *.* to test@'192.168.20.%' identified by '123.comm';

Zabbix-servre端測試是否可以採集到agent端的MySQL狀態:

[root@zabbix logs]# zabbix_get -s 192.168.20.3 -p 10050 -k "mysql.status[Uptime]"
728
#在server端執行上述命令可以看到的數字,就是數據庫相關的狀態

回到Zabbix的web頁面,添加MySQL數據庫監控模板

Zabbix監控客戶端及實現郵件、微信報警

選擇MySQL模板:

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

查看添加的MySQL監控信息(若沒有信息,則需要稍等一會):

Zabbix監控客戶端及實現郵件、微信報警

四、配置郵件報警

以下所有操作需要在Zabbix server端配置

[root@zabbix ~]# yum -y install perl-Net-SSLeay perl-IO-Socket-SSL
[root@zabbix ~]# tar zxf sendEmail-v1.56.tar.gz -C /usr/src/
[root@zabbix ~]# cp /usr/src/sendEmail-v1.56/sendEmail /usr/local/bin/
[root@zabbix ~]# chown zabbix:zabbix /usr/local/bin/sendEmail 
[root@zabbix ~]# vim /usr/local/bin/sendEmail 
        if (! IO::Socket::SSL->start_SSL($SERVER)) {
#跳轉到1906行,修改如上,然後保存退出

在進行接下來的操作前,需要有自己郵箱的授權碼,這裏以QQ爲例(163或者新浪都可以)。

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

根據提示發送信息:

Zabbix監控客戶端及實現郵件、微信報警

需要的就是以下授權碼:

Zabbix監控客戶端及實現郵件、微信報警


#Zabbix  Server上編寫郵件報警腳本
[root@zabbix alertscripts]# pwd    #所有腳本必須在該目錄下
/usr/local/zabbix/share/zabbix/alertscripts
[root@zabbix alertscripts]# vim SendEmail.sh     #腳本如下:
#!/bin/bash
to=$1
subject=$2
body=$3/usr/local/bin/sendEmail -o tls=auto -f [email protected] -t "$to" -s smtp.qq.com -u "$subject" -o message-content-type=html -o message-charset=utf8 -xu [email protected] -xp xphunzguzeibdag -m "$body"
#各項解釋如下:
# /usr/local/bin/sendEmail:命令主程序;
# -f [email protected] :發件人郵箱
# -t [email protected] :收件人郵箱
# -s smtp.126.com :發件人郵箱的 smtp 服務器
# -u "我是郵件主題" :郵件的標題 
#-o message-content-type=html:郵件內容的格式,html 表示它是 html 格式
# -o message-charset=utf8:郵件內容編碼
# -xu [email protected]:發件人郵箱的用戶名
# -xp WEE78@12l$ #發件人郵箱授權碼(就是我剛剛生成的那個授權碼)
# -m "我是郵件內容" :郵件的具體內容
#測試是否可以成功發送郵件
[root@zabbix alertscripts]# chmod +x SendEmail.sh     #給與腳本執行權限
[root@zabbix logs]# sh SendEmail.sh [email protected] test 123456
Nov 09 22:17:55 zabbix sendEmail[9970]: Email was sent successfully!

我收到的郵件如下:

Zabbix監控客戶端及實現郵件、微信報警

回到web界面,添加報警媒介

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

確認已添加報警媒介:

Zabbix監控客戶端及實現郵件、微信報警

將報警媒介關聯到用戶

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

創建一個觸發動作

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

設置“恢復操作”

配置當故障恢復後執行的操作:

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

配置觸發器

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

確定可以看到我們配置的觸發器:

Zabbix監控客戶端及實現郵件、微信報警

報警測試:

將agent端服務器的zabbix_agent進程關閉,郵箱可以收到郵件則表示配置正確。

#在agent服務器進行以下操作
[root@agent ~]# /etc/init.d/zabbix_agentd stop    #關閉agent進程

至此,即可收到報警郵件如下:

Zabbix監控客戶端及實現郵件、微信報警

五、配置企業微信報警

網頁搜索企業微信並登陸到企業微信並且自行註冊,然後進行以下操作:

創建應用:

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警
應用程序創建成功後,會顯示應用信息,如下:
Zabbix監控客戶端及實現郵件、微信報警

在上面重點記錄下此應用的Agent和Secret,以便後面配置中使用。

查看企業ID、部門ID、用戶賬號等信息:

企業ID:

Zabbix監控客戶端及實現郵件、微信報警

部門ID:
Zabbix監控客戶端及實現郵件、微信報警

用戶賬號:

Zabbix監控客戶端及實現郵件、微信報警

以上查看的信息,以後都要用到。

Zabbix server上獲取微信報警腳本。

[root@zabbix alertscripts]# pwd
/usr/local/zabbix/share/zabbix/alertscripts
[root@zabbix alertscripts]# wget https://www.ixdba.net/zabbix/weixin_linux_amd64
#若上面的地址失效,也可從博文開頭的網盤鏈接中獲取
[root@zabbix alertscripts]# mv weixin_linux_amd64 weixin   #更改名稱
[root@zabbix alertscripts]# chmod 755 weixin    #賦予執行權限
[root@zabbix alertscripts]# echo "AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts" >> /usr/local/zabbix/etc/zabbix_server.conf
#向Zabbix主配置文件中追加上述內容
#測試這個腳本是否可用,執行下面的命令(需要修改相應的值):
[root@zabbix alertscripts]# ./weixin --corpid=ww829ec5c69739bbee --corpsecret=n0CcdnCzqQHUlJSdPC8C_VDr4XXzizK2sjDMUkng0b0 --msg="微信告警測試" --user=LvJianZhao --agentid=1000004
{"errcode":0,"errmsg":"ok","invaliduser":""}
#需要修改的內容如下:
# corpid=企業號裏面的企業ID;
# corpsecret:這裏就是我們自建應用裏面的Secret的ID;
# agentid:我們自建應用裏面的AgentId;
# msg:要發送的消息內容;
# user:我們接受消息的用戶賬號,注意是在微信企業號裏面成員詳情頁的賬號;

執行完畢後,沒有報錯的話,那麼我們就可以在企業微信號上收到了這條命令的告警信息了,如下:

Zabbix監控客戶端及實現郵件、微信報警

登陸到web界面,創建微信報警媒介

Zabbix監控客戶端及實現郵件、微信報警
Zabbix監控客戶端及實現郵件、微信報警

關聯到Zabbix管理用戶:
Zabbix監控客戶端及實現郵件、微信報警
Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

注意上面的收件人設置,這個收件人就是在微信企業號後臺中,通訊錄下面的成員詳情看到的賬號,一定不要寫錯了。

確定已經添加:

Zabbix監控客戶端及實現郵件、微信報警

配置動作

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警

Zabbix監控客戶端及實現郵件、微信報警
上述填寫的內容,可從下面複製:

服務器:{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}

Zabbix監控客戶端及實現郵件、微信報警

添加後如下:

Zabbix監控客戶端及實現郵件、微信報警

配置恢復操作:

Zabbix監控客戶端及實現郵件、微信報警

以上添加的內容,可以從下面複製:

服務器:{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}

確定無誤後,點擊添加:

Zabbix監控客戶端及實現郵件、微信報警

至此,微信告警整合Zabbix就配置完成了,如下:

Zabbix監控客戶端及實現郵件、微信報警

測試微信告警功能:

#在agent進行以下操作,以便模擬故障
[root@agent ~]# /etc/init.d/zabbix_agentd stop

關閉agent端後,稍後企業微信端(郵箱也會收到)即可收到以下信息:

Zabbix監控客戶端及實現郵件、微信報警

#啓動agent端,測試恢復操作:
[root@agent ~]# /etc/init.d/zabbix_agentd start     

企業微信收到的信息如下:

Zabbix監控客戶端及實現郵件、微信報警

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章