作者 乐维社区(forum.lwops.cn) 许远
一、场景模拟
小东是一名资深的IT运维人员,其直属领导想要了解公司业务系统的健康状态以及小东日常的工作情况等,要求小东每周统计系统告警情况并发邮件给到他。小东所在公司搭建了一套zabbix开源监控,于是小东利用自己的专业知识,实现了zabbix告警统计,并生成漂亮的告警报表发送给自己的领导,得到了领导的称赞。
Zabbix开源监控是IT监控领域的佼佼者,拥有强大的告警统计与报表生成能力,但对于刚上手的小白来说可能还有些难度,本文将详细介绍zabbix告警报表的生成过程及发送邮件的操作步骤。
二、实现原理
环境说明:本人部署的zabbix版本为6.0加postgresql14.4数据库,如果用mysql的话,查询语句可能不一致
1、数据来源
基于python脚本实现,安装psqcopg2库,查询pg数据库的数据,主要是统计出最近一个月内告警出现最多的触发器,返回10-20条数据即可。统计最近一个月内哪些对象出现的告警次数比较多,我个人的话,返回的数据是1000条
2、数据清理
把主要是统计出最近一个月内告警出现最多的触发器的数据整理成一个列表数据,数据格式如下
[{“告警标签”},{“触发器名称”},{“告警次数”},{“告警颜色”}]
统计最近一个周内哪些对象出现的告警次数比较多(本人加了限制,就是一个对象同一个触发器起码一周内出现超过5次才统计),我个人的话,返回的数据是1000条
[{“对象名称”},{“对象ip”},{“触发器名称”},{“告警出现次数”}]
3、脚本实现过程
通过python脚本把最近一个月告警出现最多的触发器动态封装成html发到邮件正文。把一周内哪些对象出现的告警次数多的填充到excel表,并作为附件发送到邮件
三、实现步骤
需要安装一下python库
部分代码
Postgresql数据库连接代码
数据清洗封装动态html部分代码(有些css样式在邮件会不生效,所以可能需要用内嵌style)
邮件发送部分代码
四、成果演示
1、邮件一个月的告警统计报表
2、告警统计excel邮件附件(部分宏值需要额外替换成具体值)
以上就是本篇的全部内容,更多运维技巧欢迎关注乐维社区,更多运维问题也欢迎到乐维社区留言提问。