Terraform多环境部署:模块化配置一次搞定

Prometheus通过自定义告警规则和Grafana可视化,可实现监控数据实时展示与异常告警,核心步骤包括规则配置、Alertmanager集成和Grafana面板设计。

一、自定义Prometheus告警规则

1. 规则文件结构(以CPU使用率告警为例)
复制代码
yaml

groups: - name: server_alerts # 规则组名称 rules: - alert: HighCPUUsage # 告警名称 expr: avg(rate(node_cpu_seconds_total{mode!="idle"}[5m])) by (instance) > 0.8 # PromQL表达式,5分钟内CPU使用率平均值>80% for: 2m # 持续2分钟满足条件触发告警 labels: severity: warning # 告警级别(warning/critical) annotations: summary: "实例 {``{ $labels.instance }} CPU使用率过高" description: "CPU使用率持续2分钟超过80%,当前值: {``{ $value | humanizePercentage }}" # 格式化显示百分比

2. 配置Prometheus加载规则

prometheus.yml中添加规则文件路径:

复制代码
yaml

rule_files: - "alert_rules.yml" # 规则文件路径(支持通配符如alert_*.yml)

3. 重启Prometheus使规则生效
复制代码
bash

# Docker部署方式 docker restart prometheus # 二进制部署方式 kill -HUP $(pidof prometheus) # 热重启,不中断服务

二、配置Alertmanager(告警通知管理)

1. 安装Alertmanager
复制代码
bash

# 下载并解压 wget https://github.com/prometheus/alertmanager/releases/download/v0.25.0/alertmanager-0.25.0.linux-amd64.tar.gz tar xvfz alertmanager-0.25.0.linux-amd64.tar.gz cd alertmanager-0.25.0.linux-amd64

2. 配置告警通知(以邮件为例)

编辑alertmanager.yml

复制代码
yaml

global: resolve_timeout: 5m # 告警解决后5分钟发送恢复通知 route: group_by: ['alertname'] # 按告警名称分组 group_wait: 10s # 组内第一个告警触发后等待10s再发送 receiver: 'email' # 默认接收者 receivers: - name: 'email' email_configs: - to: 'admin@example.com' from: 'alert@example.com' smarthost: 'smtp.example.com:587' auth_username: 'alert@example.com' auth_password: 'your_password' send_resolved: true # 发送告警恢复通知

3. 启动Alertmanager并关联Prometheus
复制代码
bash

# 启动Alertmanager ./alertmanager --config.file=alertmanager.yml # 在prometheus.yml中配置Alertmanager地址 alerting: alertmanagers: - static_configs: - targets: ['localhost:9093'] # Alertmanager默认端口9093

三、Grafana可视化告警指标

1. 添加Prometheus数据源
  • 登录Grafana(默认地址http://localhost:3000,账号admin/admin)。
  • 左侧菜单 Configuration → Data Sources → Add data source → Prometheus
  • 输入Prometheus地址(如http://localhost:9090),点击 Save & Test
2. 创建告警指标面板
  • 新建Dashboard,添加Panel,选择 Prometheus 数据源。

  • 输入PromQL查询:avg(rate(node_cpu_seconds_total{mode!="idle"}[5m])) by (instance),绘制CPU使用率曲线。

  • Alert 标签页配置Grafana本地告警(可选,与Prometheus告警互补)。

四、测试告警流程

  1. 模拟高CPU负载

    复制代码
    bash

    stress --cpu 4 --timeout 300 # 用stress工具使CPU使用率飙升

  2. 查看告警状态

    • Prometheus UI(http://localhost:9090/alerts)查看告警触发状态。

    • 检查邮箱是否收到Alertmanager发送的告警通知。

相关推荐
阿里云云原生11 小时前
巨人网络《超自然行动组》携手阿里云打造云原生游戏新范式
云原生
71ber16 小时前
深入理解 HAProxy:四层/七层透传与高级 ACL 调度详解
linux·云原生·haproxy
A-刘晨阳16 小时前
K8S 之 DaemonSet
运维·云原生·容器·kubernetes·daemonset
2501_9481142419 小时前
资深程序员真实测评:9家中转API平台实战横评
微服务·云原生·架构
切糕师学AI20 小时前
Kubernetes 中的 Volume(存储卷)
云原生·容器·kubernetes
DeepFlow 零侵扰全栈可观测20 小时前
使用 eBPF 零代码修改绘制全景应用拓扑
java·前端·网络·分布式·微服务·云原生·云计算
ghostwritten21 小时前
worker01 NotReady 排查与修复步骤
云原生·kubernetes
予枫的编程笔记1 天前
【Docker基础篇】Docker入门必看:镜像、容器、仓库的关系,用类比讲得明明白白
docker·云原生·后端开发·docker架构·docker入门·镜像与容器·程序员干货
xixiyuguang1 天前
解决Docker启动后自动生成docker0虚拟网卡(172.17.0.1)及启动失败问题
云原生·eureka