需求:監控某臺web的80端口鏈接數,並出圖
兩步:
1 zabbix監控中心建立監控項目;
2 針對該監控項目以圖形展示python
#! /bin/bash ##獲取80端口併發鏈接 netstat -ant grep ':80' |grep -c ESTABLISHED #演示以下: [root@qingyun-02 ~]# vim /usr/local/sbin/estab.sh [root@qingyun-02 ~]# cat !$ cat /usr/local/sbin/estab.sh #! /bin/bash netstat -ant grep ':80' |grep -c ESTABLISHED #設置755權限 [root@qingyun-02 ~]# chmod 755 /usr/local/sbin/estab.sh [root@qingyun-02 ~]# ls -lh !$ ls -lh /usr/local/sbin/estab.sh -rwxr-xr-x 1 root root 58 2月 2 14:59 /usr/local/sbin/estab.sh
UnsafeUserParameters=1 //表示使用自定義腳本 UserParameter=my.estab.count[*],/usr/local/sbin/estab.sh #自定義監控項的key爲my.estab.count ,後面的[*]裏面寫腳本的參數 #若是沒有參數則能夠省略 #腳本爲/usr/local/sbin/estab.sh
[root@qingyun-02 ~]# systemctl restart zabbix-agent
[root@qingyun-01 fonts]# zabbix_get -s 192.168.21.132 -p 10050 -k 'my.estab.count'
其餘能夠維持默認便可,完成後點擊下面的 添加web
定義目錄vim
[root@qingyun-01 fonts]# vim /etc/zabbix/zabbix_server.conf
#! /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','password','1234567@qq.com',to,subject,content) if __name__ == "__main__": main() #####腳本使用說明###### #1. 首先定義好腳本中的郵箱帳號和密碼 #2. 腳本執行命令爲:python mail.py 目標郵箱 "郵件主題" "郵件內容" [root@qingyun-01 ~]# chmod 755 /usr/lib/zabbix/alertscripts/mail.py
建立一個接受告警郵件的用戶,「管理」 ,「用戶」 , 「建立用戶」 ,「報警媒介」 , 類型選擇 「baojing」
注意 用戶的權限,若是沒有須要到用戶組去設置權限
瀏覽器
HOST:{HOST.NAME} {HOST.IP} TIME:{EVENT.DATE} {EVENT.TIME} LEVEL:{TRIGGER.SEVERITY} NAME:{TRIGGER.NAME} messages:{ITEM.NAME}:{ITEM.VALUE} ID:{EVENT.ID}