如何实现邮件的实时监控_zabbix监控-第三章-第一节 实现邮件报警

各位好,在日常工作中,我们不可能整天盯着 zabbix仪表板 来查询服务是否正常,这个时候我们就需要有途径可以通知到我们,那么根据现在的工作环境,有三种方式是大多数公司都会选择的:

2b49ade4273e6206aa65d7b346b0e547.png

我们会主要说一下如何实现通过邮件、微信、钉钉等方式来报警,这小节我们就来使用邮件的方式来报警:

1、给邮箱开通smtp

为什么要弄这个呢?因为我们在实现邮件报警的过程中,采用的不是邮箱的账号和密码,而是邮箱的账号和授权码,开启stmp就是为了成功获取授权码;在此以QQ邮箱为例:

登录邮箱只有界面如下图:

053f86adbdb45d7e301fb3776fe11551.png

点击左上角的 “设置” 按钮,如下图:

bde47f9056fa0739dc3c738a9634d4b8.png

next:

a4e17e281d9176b759caa9b13d2483d3.png

next:

在这个页面中往下滑,会发现一个 “POP3” 如下图的一个界面,开启POP3 和 IMAP 这两个选择,再后面可以看到状态是开启的,我这里是已经开通过了,你们再操作的时候根据提示来操作即可

14e333c59a771fd25cfbd950b7a78bcb.png

next:

d3d5cb1ff26b834dce1f97642e87bc83.png

如上图,然后再按照邮箱的提示继续操作,最后将生成的授权码复制出来进行保存;

2、设立触发器

我们之前说过如何创建触发器了,过程就不仔细描述了,直接截图我设计的触发器结果吧,如下图:

PS:推荐在模板里面创建触发器,而不是单独给用户创建,因为这样的话可以复用给其他主机~

PS:我的129服务器的8080端口部署了一个tomcat用来测试用,如果不知道tomcat如何部署的同学,可以百度,另外我开启了8080的防火墙,此命令之前的文章中出现过,如果忘记的同学可以往前看。

监控项设立如下:

ca8aaabc889368b912b6dea45bf2f16f.png

触发器设立如下:

8ab6bbb7689b5bf35b9a577eae6a9865.png

看一下最新数据,保证刚添加的监控是没问题的:

5db9b83c7043fc8df2c4090ca5cbf8e0.png

而后关闭 129 服务器的tomcat,看下验证下刚创建的触发器是否生效了,如下图:

c3b5321210b48951bd18c37438cc0e8e.png

以上表示我们的触发器设立好了,最后记得先把 129 的tomcat服务重新开启。

3、放置报警脚本

既然我们要让他报警,那么肯定是要有一个脚本的,我们如何写这个脚本,这个脚本放置的位置又是哪里呢?

参考我下面的脚本,只需要更改其中的两点内容即可:

myemail='你的邮箱地址'

password='你的授权码'

#!/usr/bin/python# -*- coding: utf-8 -*-from email.mime.text import MIMETextfrom email.header import Headerfrom smtplib import SMTP_SSLimport syssmtpaddr = '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'] = myemailmsg['To'] =  recvmailtry:  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”

之后看一下邮箱:

04eb56b0b0cc8b0461452b60f60fffe9.png

如上图我们收到了,发件人是我们脚本中写的邮箱,主题是“报警邮件”,内容是“测试一下”;

之后一定要注意给这个脚本添加可执行权限:

[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、报警媒介类型

管理 --> 报警媒介类型

2aae8872d31aab38c8d8f637cee1df85.png

先把自带的三个报警媒介给禁用掉:

如下图所示:

529cedb3c2b99eccda42104e26213c3b.png

点击右上角 “创建媒体类型”

b369edf6b3216be38b3435e81d7dc7a6.png

配置如下信息:

PS:在这里我们要注意,为什么添加了三个“脚本参数”,因为我们的脚本需要三个参数输入,故而进行如下配置:

{ALERT.SENDTO} :收件人

{ALERT.SUBJECT} :邮件主题

{ALERT.MESSAGE} :邮件内容

5ac847621bc457b8bbcfda40ed2b2a0a.png

而后点击 “添加” 按钮;

7、用户信息配置

管理 --> 用户

f1e05d05d2b55acc2655c65d4b264760.png

给想被接受到邮件的人配置邮箱地址:

99e44b71bd50d754957749a7cfa5006a.png

next:

597a92eff938ca3b013867414c1e8ac6.png

next:

84e23a73cb6d03eff696c16307e6ec82.png

配置成如下配置:

PS:具体信息要结合个人实际情况来写哈;

个人只接受“一般严重”、“严重”、“灾难”这三种类型的报警,别的认为没必要发送邮件。

1ec88739afc1bcf3ba91308ef74ceebc.png

而后点击 “添加” 按钮,如下图:

1e59db1d56022129fed0d39e4b731c08.png

之后点击 “更新” 按钮:

4204f848427d58e8ef8e2a3a1c023264.png

8、配置触发器动作

配置 --> 动作

f529014971262b8206938210d081cff8.png

右上角的“创建动作”

c62c2b9f60a9fac42f8d4619b2a7cf98.png

在新界面中输入名字:

c72f0aecb9f4a02426de725c11df6703.png

而后点击此界面中的“操作”按钮,进行配置

e40ff2fa0fb1c87e8fa5f3dfc9583f98.png

next:

77c6f25d51131707f69698f45e21dfe9.png

next:

PS:结合个人实际,进行如下配置:

55ae957b38cab386cd78876bc8b7af9e.png

next:

29aff3ce3b115a0c00c40cc187862de1.png

界面如下之后,点击 “恢复操作” :

c27141439d7ded799982051367d0ff85.png

这里我们一般只用简单配置一个参数,界面如下:

6c680e1fc47fa6b7e2ef28a52cf275a2.png

操作类型 --> 添加:

5b3323eea50ae5204d8636d2116ee8e0.png

而后点击 “添加” 按钮,如下图所示:

5cdf6053d3acad3d2b00fc64d077da6a.png

之后会自动返回如下界面:

51ad4336f70acc7d637c8adbb350867f.png

发现刚才添加的已经成功了;

9、关闭192.168.20.129的tomcat对应的8080端口:

[root@jier ~]# cd /home/tomcat_8080[root@jier tomcat_8080]# lsbin  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 8080root       5733   5573  0 01:50 pts/2    00:00:00 grep --color=auto 8080[root@jier tomcat_8080]# 

10、查看下zabbix仪表板主界面,看一下是否监测8080端口失败了:

18f2423ff3db7643fbf17ed34bbf67c5.png

已经监测到了失败,如上图:

我们可以看到他提示的是邮件已经发送成功:

f60df441b33153f84c64db468f718e7f.png

此时我们去邮箱里面看一下,是否已经收到报警邮件了:

5c84138290db790a3e3b8fdd3f53dcff.png

已经收到邮件了;

11、恢复192.168.20.129的8080端口,再看下有什么变化:

报警提示没有了:

08caf627dd23a3ae4b23f3b516045217.png

看下邮箱,是否有对应的恢复邮件:

bc777e3b27cb7845911b3b79257488ee.png

恭喜,已经成功的监控了8080端口,且根据存活状态发送对应的邮件,本节到此结束。

继续加油~~~

下一小节说一下如何实现微信报警~~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值