- 需求:监控某台web的80端口连接数,并出图
- 两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现
- 对于第一步,需要到客户端定义脚本,并赋予755权限,因为需要zabbix用户可以执行它
[root@akuilinux02 ~]# vim /usr/local/sbin/estab.sh
#!/bin/bash
##获取80端口并发连接数
netstat -ant |grep ':80 ' |grep -c ESTABLISHED
[root@akuilinux02 ~]# chmod 755 !$
chmod 755 /usr/local/sbin/estab.sh
- 客户端上编辑配置文件,增加两项
[root@akuilinux02 ~]# 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
- 第二步,首先到服务端验证
[root@akuilinux01 ~]# zabbix_get -s 192.168.21.129 -p 10050 -k 'my.estab.count'
0
- 然后在zabbix监控中心(浏览器)配置增加监控项目
- 给自定义的监控项创建图形
- 给自定义的监控项目做个触发器
配置邮件告警
- 使用163或者QQ邮箱发告警邮件
- 首先登录你的163邮箱,设置开启POP3、IMAP、SMTP服务,开启授权码
- 然后到监控中心设置邮件告警,“管理”,“报警媒介类型”,“创建媒体类型”
- 创建报警脚本mail.py
vim /usr/lib/zabbix/alertscripts/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('[email protected]','aaaaaaaaaa','[email protected]',to,subject,content)
if __name__ == "__main__":
main()
#####脚本使用说明######
#1. 首先定义好脚本中的邮箱账号和密码
#2. 脚本执行命令为:python mail.py 目标邮箱 "邮件主题" "邮件内容"
- 一定要修改权限
chmod 755 /usr/lib/zabbix/alertscripts/mail.py
- 创建一个接受告警邮件的用户,“管理”,“用户”,“创建用户”,“报警媒介”,类型选择“baojing”,注意用户的权限,如果没有需要到用户组去设置权限
- 设置动作,“配置”,“动作”,“创建动作”,名称写“sendmail”(自定义),“新的触发条件”,A维护状态 非在 维护,B触发器示警度>=未分类
- 设置操作,点击操作 --> 把默认信息全部删除掉 -->定义新的默认信息 -->点击新的 --> 发送到用户 --> 选择Anna -->选择 -->仅送到 -->选择报警 -- >点击新的 --> 条件 -->添加 --> 点完添加会看到:发送消息给用户-->添加
HOST:{HOST.NAME} {HOST.IP} -->定义hostname
TIME:{EVENT.DATE} {EVENT.TIME} -->定义时间
LEVEL:{TRIGGER.SEVERITY} -->就是前面定义的是触发示警度
NAME:{TIRGGER.NAME} --> 哪个触发器发生了报警
messages:{ITEM.NAME}:{ITEM.VALUE} --> 当发生报警的时候,会有什么状态码
ID:{EVENT.ID} --> 事件ID
- 设置恢复操作(当负载很高的时候要发告警邮件,但当负载变成ok的时候也要发),点击恢复 -->把默认信息全部删除 --> 定义默认信息 --> 点击新的 -->发送到用户 -->选择Anna -->仅送到-->选择报警 -->添加
HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE} {EVENT.TIME}
LEVEL:{TRIGGER.SEVERITY}
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}
测试告警
- 故意把监控项目更改成有问题的, 设置触发器,让它告警
- 配置-->主机--> root -02 选择触发器 --> 创建触发器 --> 名称(自定义)- 系统负载 --> 添加
-->最新的T值<N --> N 设置为1 ; 当小于1的时候就告警,正常情况下负载是0 ,那么就会马上告警
- 把负载值更回正常的,也会收到ok的邮件,如果设置回正常,仍然收不到邮件,那么检查恢复操作.
不发邮件的问题处理
- 检查发邮件的脚本
- 检查Zabbix 监控中心 -- 用户设置及检查报警媒介,查看收件人邮箱地址是否有误
- 检查用户权限是否是读写,若不是将无法收到告警邮件
- 检查动作--操作是否有选择发送到用户