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

 添加自定义监控项目:

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

需求:监控某台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 条评论
登录 后参与评论

相关文章

来自专栏向治洪

认识Kubernates(K8S)

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

8028
来自专栏格子的个人博客

mysql5.7.21安装和主从同步

很久之前就做过mysql的部分应用架构,包括主从复制和集群等,一直没有形成博客记录下来,虽然网上也有很多的相关资料,但是出于加深记忆,还是把自己的操作步骤和截图...

1371
来自专栏北京马哥教育

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

1785
来自专栏乐沙弥的世界

Oracle Data Guard 重要配置参数

    Oracle Data Guard主要是通过为生产数据库提供一个或多个备用数据库(是产生数据库的一个副本),以保证在主库不可用或异常时数据不丢失并通过备...

1422
来自专栏前端萌媛的成长之路

一波webpack

1924
来自专栏linux运维学习

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

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

2356
来自专栏散尽浮华

Linux系统下的ssh使用(依据个人经验总结)

对于linux运维工作者而言,使用ssh远程远程服务器是再熟悉不过的了!对于ssh的一些严格设置也关系到服务器的安全维护,今天在此,就本人工作中使用ssh的经验...

7467
来自专栏白驹过隙

Socket编程回顾,一个最简单服务器程序

2293
来自专栏农夫安全

【原创】中间件测试方法总结---(1)

前言 之前讲了一些关于中间件的漏洞,本次来详细介绍一下对于常见中间件漏洞的测试,转载请说明来源,禁止用于非法和商业用途,多谢老铁支持 0x01 测试目...

4696
来自专栏龙首琴剑庐

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

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

5027

扫码关注云+社区

领取腾讯云代金券