原 添加自定义监控项目,配置邮件告警,测

 添加自定义监控项目:

在客户端写脚本然后在服务端检测脚本。

需求:监控某台web的80端口连接数,并出图

两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现

对于第一步,需要到客户端定义脚本

vim /usr/local/sbin/estab.sh //内容如下

#!/bin/bash
##获取80端口并发连接数
netstat -ant |grep ':80 ' |grep -c ESTABLISHED
chmod 755 /usr/local/sbin/estab.sh
客户端上编辑配置文件 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前端新创建一个报警。

{ALERT.SENDTO}     = 邮件接收者
{ALERT.SUBJECT}    = 邮件主题
{ALERT.MESSAGE}   = 邮件内容

在服务端上面配置文件里面找到路径:vi /etc/zabbix/zabbix_server.conf

进入配置文件以后然后搜索 AlertScriptsPath 找到/ usr/lib/zabbix/alertscripts 目录

进入到 /usr/lib/zabbix/alertscripts/ 里面,创建一个在zabbix上定义过名称的脚本

然后在创建的里面里面写入代码。

https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D22Z/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()
    
    
#####脚本使用说明######
#1. 首先定义好脚本中的邮箱账号和密码
#2. 脚本执行命令为:python mail.py 目标邮箱 "邮件主题" "邮件内容"

代码写入完以后还需要修改一下里面的:使用邮箱,邮箱账号,邮箱授权码 等等。

邮箱都填写ok以后,我们还需要给脚本一个执行的权限,然后就可以测试脚本了。

测试脚本命令:python mail.py 邮件接收者 “邮件的主题” “邮件的内容”

上面全部配置完以后,第二步我们就需要去给zabbix创建一个用户

设置用户

设置报警媒介

还需要设置一下权限:

全部配置完成以后,都检查一下是否有问题没问题就继续配置其他动作。

还需要配置一个动作:

配置动作

配置操作

配置操作里面的默认信息:

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

配置恢复操作

恢复操作里面的默认信息:

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 ,那么就会马上告警

点击Zabbix -->查看最近20个问题

可以看到动作完成1,说明可以正常发送邮件

#查看邮件,是可以收到告警邮件的

#原本负载值更改为1了,就会马上告警,那么现在把负载值更回正常的,也会收到ok的邮件   若是设置回正常,仍然收不到邮件,那么检查恢复操作.

不发邮件的问题处理:

1.检查发邮件的脚本

[root@aminglinux-01 alertscripts]# python mail.py anna_wqd@163.com "test" "This is test jiaoben"

[root@aminglinux-01 alertscripts]# ls -lt mail.py 
-rwxr-xr-x. 1 root root 1163 9月  11 12:42 mail.py

可以收到邮件,说明脚本ok

2. 检测Zabbix 监控中心 -- 用户设置

检查报警媒,查看收件人邮箱地址是否有误

说明:点击管理 -->用户 -->报警媒介; 

检查用户权限是否是读写,若不是将无法收到告警邮件

3.检查Zabbix 监控中心 --动作

检查动作--操作是否有选择发送到用户(Anna)

说明:点击配置-->动作-->发邮件-->条件

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏北京马哥教育

记一次惊心的网站 TCP 队列问题排查经历

1455
来自专栏james大数据架构

分布式监控系统Zabbix3.2给异常添加邮件报警

  在前一篇 分布式监控系统Zabbix3.2跳坑指南 中已安装好服务端和客户端,此处客户端是被监控的服务器,可能有上百台服务器。监控的目的一个是可以查看历史状...

2389
来自专栏IT笔记

本地私服仓库nexus3.3.1使用手册

私服架构 私服是指私有服务器,是架设在局域网的一种特殊的远程仓库,目的是代理远程仓库及部署第三方构建。有了私服之后,当 Maven 需要下载构件时,直接请求私服...

8547
来自专栏jeremy的技术点滴

MariaDB Galera Cluster部署实战

1K6
来自专栏北京马哥教育

NFS实现(双httpd + php-fpm + nfs + mysql 搭建discuz论坛)

NFS相关介绍 一、NFS简介 1. NFS(Network File System): NFS是一个文件共享协议, 也是是在类Unix系统中在内核中实现的文件...

3347
来自专栏向治洪

认识Kubernates(K8S)

在后端开发中,在介绍Jenkins的可伸缩部署方式上,主要有两种方式:一种是基于Docker(或者docker-swarm 集群)的部署方式,另外一种是基于ku...

5978
来自专栏北京马哥教育

DNS从入门到管理(一)

DNS概述 DNS(Domain Name System,域名系统),域名和IP地址相互映射的一个分布式数据库,通过主机名,最终得到该主机名对应的IP地址的过程...

5426
来自专栏linux运维学习

linux学习第四十一篇:配置防盗链,访问控制Directory,访问控制FilesMatch

配置防盗链 防盗链,就是不让别人盗用你网站上的资源,这个资源,通常指的是图片,视频,歌曲,文档等。不是我们认识的referer一概不许访问。 防盗链的...

2256
来自专栏龙首琴剑庐

基于复杂方案OWSAP CsrfGuard的CSRF安全解决方案(适配nginx + DWR)

1、什么是CSRF? 已经有很多博文讲解其过程和攻击手段,在此就不重复了。 O(∩_∩)O 不清楚的同学,请自行搜索或按链接去了解: http://blog...

3877
来自专栏沃趣科技

ASM 翻译系列第二十弹:ASM Internal ASM file number 7

原作者:Bane Radulovic 译者: 郭旭瑞 审核: 魏兴华 DBGeeK社群联合出品 ASM file number 7 ASM元信息7号...

3737

扫码关注云+社区