zabbix监控-第三章-第一节 实现邮件报警
suiw9 2024-11-16 00:34 16 浏览 0 评论
各位好,在日常工作中,我们不可能整天盯着 zabbix仪表板 来查询服务是否正常,这个时候我们就需要有途径可以通知到我们,那么根据现在的工作环境,有三种方式是大多数公司都会选择的:
我们会主要说一下如何实现通过邮件、微信、钉钉等方式来报警,这小节我们就来使用邮件的方式来报警:
1、给邮箱开通smtp
为什么要弄这个呢?因为我们在实现邮件报警的过程中,采用的不是邮箱的账号和密码,而是邮箱的账号和授权码,开启stmp就是为了成功获取授权码;在此以QQ邮箱为例:
登录邮箱只有界面如下图:
点击左上角的 “设置” 按钮,如下图:
next:
next:
在这个页面中往下滑,会发现一个 “POP3” 如下图的一个界面,开启POP3 和 IMAP 这两个选择,再后面可以看到状态是开启的,我这里是已经开通过了,你们再操作的时候根据提示来操作即可
next:
如上图,然后再按照邮箱的提示继续操作,最后将生成的授权码复制出来进行保存;
2、设立触发器
我们之前说过如何创建触发器了,过程就不仔细描述了,直接截图我设计的触发器结果吧,如下图:
PS:推荐在模板里面创建触发器,而不是单独给用户创建,因为这样的话可以复用给其他主机~
PS:我的129服务器的8080端口部署了一个tomcat用来测试用,如果不知道tomcat如何部署的同学,可以百度,另外我开启了8080的防火墙,此命令之前的文章中出现过,如果忘记的同学可以往前看。
监控项设立如下:
触发器设立如下:
看一下最新数据,保证刚添加的监控是没问题的:
而后关闭 129 服务器的tomcat,看下验证下刚创建的触发器是否生效了,如下图:
以上表示我们的触发器设立好了,最后记得先把 129 的tomcat服务重新开启。
3、放置报警脚本
既然我们要让他报警,那么肯定是要有一个脚本的,我们如何写这个脚本,这个脚本放置的位置又是哪里呢?
参考我下面的脚本,只需要更改其中的两点内容即可:
myemail='你的邮箱地址'
password='你的授权码'
#!/usr/bin/python
# -*- coding: utf-8 -*-
from email.mime.text import MIMEText
from email.header import Header
from smtplib import SMTP_SSL
import sys
smtpaddr = 'smtp.qq.com'
myemail='2276845534@qq.com'
password='gohbjgpbrdgadime'
recvmail=sys.argv[1]
subject=sys.argv[2]
content=sys.argv[3]
msg = MIMEText("""%s"""%(content), "plain", "utf-8")
msg['Subject'] = Header(subject, 'utf-8').encode()
msg['From'] = myemail
msg['To'] = recvmail
try:
smtp = SMTP_SSL( smtpaddr )
smtp.login(myemail, password)
smtp.sendmail(myemail, recvmail.split(','), msg.as_string())
smtp.quit()
print("success")
except Exception as e:
print("fail: "+str(e))
从上面的脚本可以看到,我们分别接受三个参数,那就是 “收件人”, “邮件主题”, “邮件内容”;
下面我们也就针对这三个进行设置;
4、放置到zabbix_server也就是192.168.20.128这台服务器上:
[root@bogon ~]# cd /home/zabbix/share/zabbix/alertscripts
[root@bogon alertscripts]# touch email_qq.py
[root@bogon alertscripts]# vim email_qq.py
# 将上面的脚本复制进来
# 然后保存退出
5、测试一下脚本
[root@bogon alertscripts]# python email_qq.py 2276845534@qq.com "报警邮件" "测试一下"
会提示出来“success”
之后看一下邮箱:
如上图我们收到了,发件人是我们脚本中写的邮箱,主题是“报警邮件”,内容是“测试一下”;
之后一定要注意给这个脚本添加可执行权限:
[root@bogon alertscripts]# chmod +x email_qq.py
[root@bogon alertscripts]# ll email_qq.py
-rwxr-xr-x. 1 root root 656 2月 23 02:01 email_qq.py
[root@bogon alertscripts]#
6、报警媒介类型
管理 --> 报警媒介类型
先把自带的三个报警媒介给禁用掉:
如下图所示:
点击右上角 “创建媒体类型”
配置如下信息:
PS:在这里我们要注意,为什么添加了三个“脚本参数”,因为我们的脚本需要三个参数输入,故而进行如下配置:
{ALERT.SENDTO} :收件人
{ALERT.SUBJECT} :邮件主题
{ALERT.MESSAGE} :邮件内容
而后点击 “添加” 按钮;
7、用户信息配置
管理 --> 用户
给想被接受到邮件的人配置邮箱地址:
next:
next:
配置成如下配置:
PS:具体信息要结合个人实际情况来写哈;
个人只接受“一般严重”、“严重”、“灾难”这三种类型的报警,别的认为没必要发送邮件。
而后点击 “添加” 按钮,如下图:
之后点击 “更新” 按钮:
8、配置触发器动作
配置 --> 动作
右上角的“创建动作”
在新界面中输入名字:
而后点击此界面中的“操作”按钮,进行配置
next:
next:
PS:结合个人实际,进行如下配置:
next:
界面如下之后,点击 “恢复操作” :
这里我们一般只用简单配置一个参数,界面如下:
操作类型 --> 添加:
而后点击 “添加” 按钮,如下图所示:
之后会自动返回如下界面:
发现刚才添加的已经成功了;
9、关闭192.168.20.129的tomcat对应的8080端口:
[root@jier ~]# cd /home/tomcat_8080
[root@jier tomcat_8080]# ls
bin BUILDING.txt conf CONTRIBUTING.md lib LICENSE logs NOTICE README.md RELEASE-NOTES RUNNING.txt temp webapps work
[root@jier tomcat_8080]# ./bin/shutdown.sh
[root@jier tomcat_8080]# ps -ef | grep 8080
root 5733 5573 0 01:50 pts/2 00:00:00 grep --color=auto 8080
[root@jier tomcat_8080]#
10、查看下zabbix仪表板主界面,看一下是否监测8080端口失败了:
已经监测到了失败,如上图:
我们可以看到他提示的是邮件已经发送成功:
此时我们去邮箱里面看一下,是否已经收到报警邮件了:
已经收到邮件了;
11、恢复192.168.20.129的8080端口,再看下有什么变化:
报警提示没有了:
看下邮箱,是否有对应的恢复邮件:
恭喜,已经成功的监控了8080端口,且根据存活状态发送对应的邮件,本节到此结束。
继续加油~~~
下一小节说一下如何实现微信报警~~~
相关推荐
- 俄罗斯的 HTTPS 也要被废了?(俄罗斯网站关闭)
-
发布该推文的ScottHelme是一名黑客,SecurityHeaders和ReportUri的创始人、Pluralsight作者、BBC常驻黑客。他表示,CAs现在似乎正在停止为俄罗斯域名颁发...
- 如何强制所有流量使用 HTTPS一网上用户
-
如何强制所有流量使用HTTPS一网上用户使用.htaccess强制流量到https的最常见方法可能是使用.htaccess重定向请求。.htaccess是一个简单的文本文件,简称为“.h...
- https和http的区别(https和http有何区别)
-
“HTTPS和HTTP都是数据传输的应用层协议,区别在于HTTPS比HTTP安全”。区别在哪里,我们接着往下看:...
- 快码住!带你十分钟搞懂HTTP与HTTPS协议及请求的区别
-
什么是协议?网络协议是计算机之间为了实现网络通信从而达成的一种“约定”或“规则”,正是因为这个“规则”的存在,不同厂商的生产设备、及不同操作系统组成的计算机之间,才可以实现通信。简单来说,计算机与网络...
- 简述HTTPS工作原理(简述https原理,以及与http的区别)
-
https是在http协议的基础上加了一层SSL(由网景公司开发),加密由ssl实现,它的目的是为用户提供对网站服务器的身份认证(需要CA),以至于保护交换数据的隐私和完整性,原理如图示。1、客户端发...
- 21、HTTPS 有几次握手和挥手?HTTPS 的原理什么是(高薪 常问)
-
HTTPS是3次握手和4次挥手,和HTTP是一样的。HTTPS的原理...
- 一次安全可靠的通信——HTTPS原理
-
为什么HTTPS协议就比HTTP安全呢?一次安全可靠的通信应该包含什么东西呢,这篇文章我会尝试讲清楚这些细节。Alice与Bob的通信...
- 为什么有的网站没有使用https(为什么有的网站点不开)
-
有的网站没有使用HTTPS的原因可能涉及多个方面,以下是.com、.top域名的一些见解:服务器性能限制:HTTPS使用公钥加密和私钥解密技术,这要求服务器具备足够的计算能力来处理加解密操作。如果服务...
- HTTPS是什么?加密原理和证书。SSL/TLS握手过程
-
秘钥的产生过程非对称加密...
- 图解HTTPS「转」(图解http 完整版 彩色版 pdf)
-
我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取。所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议。...
- HTTP 和 HTTPS 有何不同?一文带你全面了解
-
随着互联网时代的高速发展,Web服务器和客户端之间的安全通信需求也越来越高。HTTP和HTTPS是两种广泛使用的Web通信协议。本文将介绍HTTP和HTTPS的区别,并探讨为什么HTTPS已成为We...
- HTTP与HTTPS的区别,详细介绍(http与https有什么区别)
-
HTTP与HTTPS介绍超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的...
- 一文让你轻松掌握 HTTPS(https详解)
-
一文让你轻松掌握HTTPS原文作者:UC国际研发泽原写在最前:欢迎你来到“UC国际技术”公众号,我们将为大家提供与客户端、服务端、算法、测试、数据、前端等相关的高质量技术文章,不限于原创与翻译。...
- 如何在Spring Boot应用程序上启用HTTPS?
-
HTTPS是HTTP的安全版本,旨在提供传输层安全性(TLS)[安全套接字层(SSL)的后继产品],这是地址栏中的挂锁图标,用于在Web服务器和浏览器之间建立加密连接。HTTPS加密每个数据包以安全方...
- 一文彻底搞明白Http以及Https(http0)
-
早期以信息发布为主的Web1.0时代,HTTP已可以满足绝大部分需要。证书费用、服务器的计算资源都比较昂贵,作为HTTP安全扩展的HTTPS,通常只应用在登录、交易等少数环境中。但随着越来越多的重要...
你 发表评论:
欢迎- 一周热门
-
-
Linux:Ubuntu22.04上安装python3.11,简单易上手
-
宝马阿布达比分公司推出独特M4升级套件,整套升级约在20万
-
MATLAB中图片保存的五种方法(一)(matlab中保存图片命令)
-
别再傻傻搞不清楚Workstation Player和Workstation Pro的区别了
-
Linux上使用tinyproxy快速搭建HTTP/HTTPS代理器
-
如何提取、修改、强刷A卡bios a卡刷bios工具
-
Element Plus 的 Dialog 组件实现点击遮罩层不关闭对话框
-
日本组合“岚”将于2020年12月31日停止团体活动
-
SpringCloud OpenFeign 使用 okhttp 发送 HTTP 请求与 HTTP/2 探索
-
tinymce 号称富文本编辑器世界第一,大家同意么?
-
- 最近发表
- 标签列表
-
- dialog.js (57)
- importnew (44)
- windows93网页版 (44)
- yii2框架的优缺点 (45)
- tinyeditor (45)
- qt5.5 (60)
- windowsserver2016镜像下载 (52)
- okhttputils (51)
- android-gif-drawable (53)
- 时间轴插件 (56)
- docker systemd (65)
- slider.js (47)
- android webview缓存 (46)
- pagination.js (59)
- loadjs (62)
- openssl1.0.2 (48)
- velocity模板引擎 (48)
- pcre library (47)
- zabbix微信报警脚本 (63)
- jnetpcap (49)
- pdfrenderer (43)
- fastutil (48)
- uinavigationcontroller (53)
- bitbucket.org (44)
- python websocket-client (47)