作者:liugp
出处:https://goo.gs/8g4je
一、概述
通过创建 Prometheus 监控告警规则,您可以制定针对特定 Prometheus 实例的告警规则。当告警规则设置的条件满足后,系统会产生对应的告警事件。如果想要收到通知,需要进一步配置对应的通知策略以生成告警并且以短信、邮件、电话、钉群机器人、企业微信机器人或者 Webhook 等方式发送通知。
从 Prometheus server 端接收到 alerts 后,会基于 PromQL 的告警规则 分析数据,如果满足 PromQL 定义的规则,则会产生一条告警,并发送告警信息到 Alertmanager,Alertmanager 则是根据配置处理告警信息并发送。所以 Prometheus 的告警配置依赖于与,关于这两个介绍可以参考以下文章:
Prometheus AlertManager 实战[1]
Prometheus PromQL 实战[2]
Prometheus Pushgetway 实战[3]
官方文档:https://prometheus.io/docs/alerting/latest/overview/
二、告警实现流程
设置警报和通知的主要步骤是:
在 Prometheus 中配置告警规则。
配置 Prometheus 与 AlertManager 关联。
配置 AlertManager 告警通道。
三、告警规则
官方文档:https://prometheus.io/docs/prometheus/latest/configuration/alerting_rules/
1)告警规则配置
在 Prometheus 配置()中添加报警规则配置,配置文件中 就是用来指定报警规则文件的,如下配置即指定存放报警规则的目录为/etc/prometheus,规则文件为 rules.yml:
设置报警规则:
警报规则允许基于 Prometheus 表达式语言的表达式来定义报警报条件的,并在触发警报时发送通知给外部的接收者(Alertmanager),一条警报规则主要由以下几部分组成:
——告警规则的名称。
——是用于进行报警规则 PromQL 查询语句。
——评估告警的等待时间(Pending Duration)。
——自定义标签,允许用户指定额外的标签列表,把它们附加在告警上。
——用于存储一些额外的信息,用于报警信息的展示之类的。
rules.yml 示例如下:
1)监控服务器是否在线
对于被 Prometheus 监控的服务器,我们都有一个 up 指标,可以知道该服务是否在线。
【示例】
注意:
指定达到告警阈值之后,一致要持续多长时间,才发送告警数据。
中可以指定自定义的标签,如果定义的标签已经存在,则会被覆盖。可以使用模板。
中的数据,可以使用模板,表示告警数据的标签,表示时间序列的值。
3)告警数据的状态
——表示没有达到告警的阈值,即 expr 表达式不成立。
——表示达到了告警的阈值,即 expr 表达式成立了,但是未满足告警的持续时间,即 for 的值。
——已经达到阈值,且满足了告警的持续时间。
【温馨提示】经测试发现,如果同一个告警数据达到了 Firing,那么不会再次产生一个告警数据,除非该告警解决了。
四、实战操作
1)下载 node_exporter
node-exporter 用于采集 node 的运行指标,包括 node 的 cpu、load、filesystem、meminfo、network 等基础监控指标,类似于 zabbix 监控系统的的 zabbix-agent。
下载地址:https://github.com/prometheus/node_exporter/releases/
2)启动 node_exporter
配置启动
启动服务
检查
3)配置 Prometheus 加载 node_exporter
添加或修改配置
重启加载配置
检查
web:
4)告警规则配置
在 Prometheus 配置文件 中配置如下:
在配置如下:
重新加载
在 web 上就可以看到一个告警规则。
5)模拟告警
手动关机
过了一段时间告警状态就变成
再过一段时间告警就变成了
6)配置告警通道
这里以有邮件告警为示例,其它的也差不多。修改配置之前最好先备份一下之前的配置
【1】配置
【2】模板
模板文件配置了、、 三种模板变量,可以在 文件中直接配置引用。这里 就是要发送的邮件内容,支持 Html 和 Text 格式,这里为了显示好看,采用 Html 格式简单显示信息。下边 {{ range .Alerts }} 是个循环语法,用于循环获取匹配的 Alerts 的信息。
【温馨提示】这里记得换成自己的邮箱地址!!!
重启 alertmanager
在 web 上就可以看到对应的告警信息了。
接下来就静待告警了。
一整套流程到这里就全部跑通了,告警规则、告警指标、告警通道根据自己的场景来定
参考资料
[1]
Prometheus AlertManager 实战: https://www.cnblogs.com/liugp/p/16974615.html
[2]
Prometheus PromQL 实战: https://www.cnblogs.com/liugp/p/16977340.html
[3]
Prometheus Pushgetway 实战: https://www.cnblogs.com/liugp/p/16973756.html
领取专属 10元无门槛券
私享最新 技术干货