需求:监控某台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}