Prometheus & Grafana:算力中心的“ICU 监控系统”

Prometheus & Grafana:算力中心的"ICU 监控系统"

在管理大规模的算力中心(有很多 CPU/GPU 服务器)时,怎么知道哪台机器发烧了(过热)?哪台机器在偷懒(空闲)?

我们需要一套监控系统,而 Prometheus + Grafana 就是业界的黄金搭档。


1. 通俗比喻:ICU 病房监控

我们可以把算力中心的每一台服务器 想象成 ICU 病房里的病人

角色 1:Exporter ------ "贴在身上的传感器"

  • 是什么:一个小软件,装在被监控的服务器上。
  • 干什么 :它负责实时采集机器的生命体征。
    • Node Exporter:采集 CPU 使用率、内存剩余、硬盘读写等(就像测心率、血压)。
    • DCGM Exporter:专门采集 NVIDIA GPU 的显存占用、GPU 利用率、温度(就像测脑电波)。
  • 特点:它只负责采集并把数据暴露在通过一个 HTTP 接口上,它不知道谁来看数据。

角色 2:Prometheus ------ "负责查房的护士(数据库)"

  • 是什么:一个开源的时序数据库和监控系统。
  • 干什么 :它非常勤快,默认每隔 15 秒(可配置)就去访问所有 Exporter 的接口,问:"现在数据是多少?"。
  • 动作 :这叫 Pull(拉取)模式 。不仅记录数据,还记录时间
    • "10:00:00,机器A,GPU温度 60度"
    • "10:00:15,机器A,GPU温度 62度"
    • "10:00:30,机器A,GPU温度 85度 (危险!)"

角色 3:Grafana ------ "床头的电子显示屏(可视化)"

  • 是什么:一个超级酷炫的看图工具。
  • 干什么:Prometheus 存的都是冷冰冰的数字和时间戳,人看不懂。Grafana 负责连接 Prometheus,把这些数据画成折线图、仪表盘、热力图。
  • 效果:管理员坐在办公室,看着大屏幕,一眼就能看出哪条曲线飙升了。

2. 应用场景实战:算力中心监控

假设你运营一个拥有 100 张 H800 计算卡的算力集群,这套系统能帮你解决什么问题?

场景一:防止矿机"烧卡" ------ 硬件健康监控

  • 配置:我们在 Grafana 上画一条红线(阈值),比如 GPU 温度 > 80℃。
  • Prometheus 报警 :一旦 Prometheus 抓取的数据连续 1 分钟超过 80℃,它会立刻触发 Alertmanager,给你发钉钉、邮件或者打电话。
  • 结果:运维立刻去检查风扇或空调,避免价值几十万的显卡烧毁。

场景二:抓出"占着茅坑不拉屎"的租户 ------ 利用率分析

  • 问题:由于算力很贵,你把机器租给客户 A,但他好像没在跑任务?
  • 查看 Grafana :调出过去 24 小时的 GPU Utilization(利用率) 曲线。
  • 发现:利用率长期是一条直线的 0%,或者一直在波动但平均只有 10%。
  • 决策:你可以联系客户 A 释放资源,或者根据利用率来动态计费。

场景三:排查"卡顿"原因 ------ 性能瓶颈分析

  • 问题:客户抱怨训练模型特别慢。
  • 排查 :看监控面板。
    • CPU 跑满了? -> 可能是数据预处理太慢,卡住 GPU 了。
    • PCIe 带宽跑满了? -> 可能是数据传输这是瓶颈。
    • GPU 显存满了? -> 模型太大,需要优化 Batch Size。
  • 结果:用数据说话,快速定位是软件问题还是硬件瓶颈。

3. 为什么是"Pull"模式?(Prometheus 的一大特点)

传统的监控往往是 Agent 主动推 (Push) 数据给服务器。但 Prometheus 选择拉 (Pull)

  • 好处 :Prometheus 掌握主动权。如果某台机器宕机了(挂了),Prometheus 拉不到数据,它立刻就知道这台机器掉线了(Up 状态变为 0)。
  • 像极了:护士去病房喊病人,病人不答应,护士马上知道出事了;而不是等病人自己跑来护士站汇报(万一晕倒了怎么汇报?)。

总结

  • Exporter: 这里的传感器(生产数据)。
  • Prometheus: 勤劳的查房记录员(存储数据)。
  • Grafana: 漂亮的大屏展示(展示数据)。
相关推荐
是阿楷啊5 小时前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试
xixingzhe21 天前
Prometheus+Grafana监控服务器
grafana·prometheus
牛奶咖啡131 天前
Prometheus+Grafana构建云原生分布式监控系统(十六) _基于Alertmanager的告警机制(一)
云原生·prometheus·prometheus告警整合·prometheus告警配置·prometheus告警规则·prometheus触发告警·告警规则配置实践
南宫乘风2 天前
Loki 日志采集落地:从单机 Helm 部署到 Promtail 采集与 Grafana 查询
grafana
码农小卡拉3 天前
Prometheus 监控 SpringBoot 应用完整教程
spring boot·后端·grafana·prometheus
牛奶咖啡133 天前
Prometheus+Grafana构建云原生分布式监控系统(十五)_Prometheus中PromQL使用(二)
云原生·prometheus·集合运算·对查询结果排序·直方图原理·统计掉线的实例·检查节点或指标是否存在
咖啡啡不加糖4 天前
Grafana 监控服务指标使用指南:打造可视化监控体系
java·后端·grafana
牛奶咖啡134 天前
Prometheus+Grafana构建云原生分布式监控系统(十四)_Prometheus中PromQL使用(一)
云原生·prometheus·promql·计算一个时间范围内的平均值·将相同数据整合查看整体趋势·计算时间范围内的最大最小比率·向量标量的算术运算
世界尽头与你4 天前
(修复方案)CVE-2021-43798: Grafana路径遍历漏洞
安全·grafana
牛奶咖啡135 天前
Prometheus+Grafana构建云原生分布式监控系统(十三)_Prometheus数据模型及其PromQL
云原生·prometheus·prometheus数据类型·promql使用场景·promql表达式解析·promql数据类型·监控系统的方法论与指标