Linux學習總結(五十七)監控zabbix部署 下篇

zabbix 應用舉例python

一 添加自定義監控項目

咱們舉一個實例:監控web服務器80端口的併發鏈接數,並設置圖形。
1 . 寫一個能夠抓取數據的腳本,在客戶端zabbix-agent 上建立腳本web

vim /usr/local/sbin/estab.sh
#!/bin/bash
netstat -ant |grep ':80 ' |grep -c ESTABLISHED

保存後,給腳本777權限
腳本測試:
sh /usr/local/sbin/estab.sh 看是否報錯
2 在zabbix客戶端配置文件中 關聯腳本,定義監控項的key值,也就是腳本獲取的值,後面要在zabbix web界面中定義vim

vim /etc/zabbix/zabbix_agentd.conf  //增長兩行
UnsafeUserParameters=1  //表示使用自定義腳本
UserParameter=my.estab.count[*],/usr/local/sbin/estab.sh

//自定義監控項的key爲my.estab.count,後面的[*]裏面寫腳本的參數,若是沒有參數則能夠省略,腳本爲/usr/local/sbin/estab.sh
保存配置文件後,重啓下zabbix-agent 服務
systemctl restart zabbix-agent
檢查 配置是否正確,在服務端上執行
zabbix_get -s 192.168.226.130 -p 10050 -k 'my.estab.count' //該ip是客戶端ip,端口是客戶端端口,意思是從服務端查看監控項的key值
3 web 界面中添加監控項,能夠在主機中添加,也能夠在模板中添加。便於管理,咱們在模板中添加。
配置-模板-自定義模板的 監控項 - 建立監控項
自定義名稱,鍵值寫上面配置文件中定義的 my.estab.count,類型保持默認,(被動模式)。點擊最下面添加按鈕。
Linux學習總結(五十七)監控zabbix部署 下篇
4 設置圖形
配置-模板-自定義模板的-圖形-建立圖形
名稱自定義。 監控項添加上面建立好的監控項,點擊選擇按鈕, 選好後點擊 最後面的添加按鈕。
也能夠在主機中建立圖形。
最後效果
Linux學習總結(五十七)監控zabbix部署 下篇bash

二 配置告警

咱們模擬一個報警併發送郵件通知
1 建立告警媒介, 指定用腳本發送郵件
管理-報警媒介類型-建立媒體類型
具體操做入下圖
Linux學習總結(五十七)監控zabbix部署 下篇
2 在zabbix服務端建立腳本
cd /usr/lib/zabbix/alertscripts/
vim mail.py服務器

#!/usr/bin/env python
#-*- coding: UTF-8 -*-
import os,sys
reload(sys)
sys.setdefaultencoding('utf8')
import getopt
import smtplib
from email.MIMEText import MIMEText
from email.MIMEMultipart import MIMEMultipart
from  subprocess import *
def sendqqmail(username,password,mailfrom,mailto,subject,content):
    gserver = 'smtp.qq.com'    //更具實際狀況做更改
    gport = 25
    try:
        msg = MIMEText(unicode(content).encode('utf-8'))
        msg['from'] = mailfrom
        msg['to'] = mailto
        msg['Reply-To'] = mailfrom
        msg['Subject'] = subject
        smtp = smtplib.SMTP(gserver, gport)
        smtp.set_debuglevel(0)
        smtp.ehlo()
        smtp.login(username,password)
        smtp.sendmail(mailfrom, mailto, msg.as_string())
        smtp.close()
    except Exception,err:
        print "Send mail failed. Error: %s" % err
def main():
    to=sys.argv[1]
    subject=sys.argv[2]
    content=sys.argv[3]
##定義QQ郵箱的帳號和密碼,你須要修改爲你本身的帳號和密碼
 sendqqmail('1234567@qq.com','aaaaaaaaaa','1234567@qq.com',to,subject,content)
if __name__ == "__main__":
    main()

備註:該腳本須要修改兩個地方,第一個就是郵箱服務器,上面的 gserver = 'smtp.qq.com',若是用的是163郵箱,能夠更改成163.com,第二個地方爲sendqqmail('1234567@qq.com','aaaaaaaaaa','1234567@qq.com',to,subject,content) 這裏指定了發送方的郵箱地址,密碼以及接收方的郵箱地址,該密碼爲郵箱的客戶端受權碼,須要登錄到郵箱獲取。
Linux學習總結(五十七)監控zabbix部署 下篇
記得給腳本權限
chmod 777 mail.py
3建立一個接收告警的用戶
管理-用戶-建立用戶
Linux學習總結(五十七)監控zabbix部署 下篇
第一項用戶當中,定義名字,羣組,密碼就能夠,羣組能夠選擇zabbix administrators
第二項報警媒介
Linux學習總結(五十七)監控zabbix部署 下篇
類型選擇咱們上面建立的類型,郵箱這裏咱們指定跟發郵件地址相同。
第三項權點進去看下,若是全部組權限爲無,則進行下面操做
用戶的權限須要在用戶組裏面去分配。選擇上面指定的zabbix administrators羣組,選擇權限,選擇讀寫,選擇全部組後添加,完成會發現全部組權限由無變爲讀寫
Linux學習總結(五十七)監控zabbix部署 下篇
4 配置告警動做
配置-動做-建立動做
在子界面動做中定義動做名稱,在操做界面定義發郵件內容,清空原來的消息內容,加入如下內容併發

HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE}  {EVENT.TIME} 
LEVEL:{TRIGGER.SEVERITY} 
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}

點擊下面的"新的"打開"操做細節" 選擇發送到用戶,添加咱們剛纔定義的用戶,點擊最下面添加
恢復操做界面跟操做界面做相同處理。
至此配置完成,
5 測試告警
建立一個觸發器
配置-模板-自定義模板觸發器-建立觸發器
Linux學習總結(五十七)監控zabbix部署 下篇
當前一分鐘平均負載爲0,故意設置小於1 告警,咱們在儀表盤看到以下告警信息,而且發送了郵件
備註:我在模板中建立的觸發器,由於個人模板是關聯到主機的,固然能夠在主機中建立觸發器,也就是說咱們監控的總體邏輯要圍繞主機。可是操做均可以在模板中進行。ide

相關文章
相關標籤/搜索