0

0

Grafana如何展示服务指标_监控可视化方案

P粉602998670

P粉602998670

发布时间:2026-01-27 12:11:47

|

373人浏览过

|

来源于php中文网

原创

Prometheus+Grafana是最稳通用的服务监控方案,Prometheus专为服务指标设计,需应用自暴露/metrics,写PromQL要加流量过滤防误告警,推荐复用Node Exporter模板并用Grafana变量实现多服务/环境联动。

grafana如何展示服务指标_监控可视化方案

直接用 Prometheus + Grafana 是最稳、最通用的服务指标监控可视化方案,其他组合(如 InfluxDB)适合特定场景但生态适配成本更高。

选对数据源:Prometheus 是服务指标的默认事实标准

Prometheus 天然适配服务类指标(HTTP 请求量、错误率、延迟 P95、gRPC 状态码等),因为它的拉取模型、多维标签(jobinstanceendpointstatus_code)和 PromQL 函数(rate()histogram_quantile()sum by())专为这类时序服务指标设计。

  • 别用 InfluxDB 直接对接应用埋点——InfluxQL 缺乏原生的 rate 计算和多维下钻能力,写个“过去 5 分钟 4xx 错误占比”要嵌套子查询,易错且难维护
  • Node Exporter 只管主机层;服务指标必须由应用自己暴露 /metrics(如 Spring Boot Actuator + Micrometer、Go 的 promhttp
  • 确认你的服务已启用 Prometheus 格式指标端点,访问 http://your-service:8080/actuator/prometheus 或类似路径,能看到形如 http_requests_total{method="GET",status="200"} 12345 的原始指标

写准 PromQL:避免错误率告警误触发的两个关键

服务监控最常踩的坑是错误率计算不加流量过滤,导致低流量时段一两个失败就触发告警。核心原则:只对有真实业务流量的系列做 rate 计算。

  • ✅ 正确写法(带基数过滤):rate(http_requests_total{status=~"5.."}[5m]) / rate(http_requests_total[5m]) —— 但仅当整体请求量足够大时才可靠
  • ✅ 更健壮写法(双重保护):(rate(http_requests_total{status=~"5.."}[5m]) > 0.1) and (rate(http_requests_total[5m]) > 10) —— 要求错误率 >10% 总请求速率 >10 QPS,两者同时满足才告警
  • ❌ 危险写法:sum(rate(http_requests_total{status=~"5.."}[5m])) by (job) / sum(rate(http_requests_total[5m])) by (job) —— 如果某个 job 某分钟只发了 1 个请求且失败了,结果就是 100%,但毫无业务意义

导入还是手搭?从 Node Exporter 全景模板起步,再叠加服务专用面板

别从零建 Dashboard。Grafana 官方模板 ID 1860(Node Exporter Full)已验证稳定,覆盖 CPU、内存、磁盘、网络基础项,可直接复用其变量(如 $instance$job)和服务指标面板共用。

听脑AI
听脑AI

听脑AI语音,一款专注于音视频内容的工作学习助手,为用户提供便捷的音视频内容记录、整理与分析功能。

下载
  • 导入后,在「Variables」里检查 job 变量 query 是否包含你的服务 job 名,例如:label_values(job) → 若没显示,说明 Prometheus 还没抓到你的服务,回去检查 prometheus.yml 中的 scrape_configs
  • 新增服务面板时,Metrics browser 输入框里先输 http_requests_total,回车看是否列出带 job="my-api" 的时间序列;没有就说明采集链断在 exporter 或网络层
  • 高频操作:点击面板右上角 ⋯ → Edit → Metrics → Add query,不要反复新建面板——一个 Dashboard 放 6–12 个相关面板即可,太多反而干扰判断

变量联动:让一个 Dashboard 同时查多个服务、多个环境

靠手动改 PromQL 里的 job="prod-api" 切换服务?太慢还易错。用 Grafana 变量实现一键切换。

  • 新增变量 → Name 填 service → Query 类型选 Label values → Label 填 job → Metric 填 http_requests_total(确保该指标在所有目标服务中都存在)
  • 在所有 PromQL 中把硬编码替换为 {job=~"$service"},支持多选(按住 Ctrl);若只想单选,Variable 设置里勾选 Multi-valueInclude All option
  • 进阶:用 Query result 类型变量做级联筛选,比如先选 env="prod",再自动列出该环境下所有 job —— 查询写成:label_values(http_requests_total{env="$env"}, job)

真正难的不是画图,而是让每个指标背后都有明确的 SLO 意义:这个 P95 延迟超多少算影响用户体验?那个错误率持续多久才值得人半夜爬起来?可视化只是把问题摊开,决策依据得提前和业务方对齐。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

181

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

229

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

342

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

209

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

394

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

220

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

192

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

376

2025.06.17

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 19万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号