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发送的告警通知。

相关推荐
阿里云云原生1 天前
阿里云可观测 2026 年 4 月产品动态
云原生
阿里云云原生1 天前
Skills Registry 公测开启:为企业打造私有的 Skill 管理中心
云原生
吃胖点儿1 天前
DevOps与自动化原理
云原生
PH = 72 天前
K8S集群部署Dashboard
云原生·容器·kubernetes
掘根2 天前
【微服务即时通讯项目】用Docker部署服务端
微服务·云原生·架构
陈陈CHENCHEN2 天前
【Kubernetes】Ubuntu 24.04 二进制方式部署 K8s
云原生·容器·kubernetes
AI攻城狮2 天前
VSCode 的黄昏:AI 原生 IDE 时代,那个轻量神器正在变成历史包袱
云原生
AI攻城狮2 天前
修复 AI Gateway 图片 MIME 类型错误:用魔数检测替代扩展名猜测
云原生
成为你的宁宁2 天前
【K8s Service 基础知识、五大类型应用机制及Endpoint 深度解析】
云原生·容器·kubernetes
老卢聊运维2 天前
K8s 资源一直 Terminating?kubectl 强制删除完整实操手册
云原生·容器·kubernetes