首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

16 张图实战 Prometheus 自定义告警规则

作者: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

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20221221A08QND00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券
http://www.vxiaotou.com