0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Prometheus Metric的实践总结

马哥Linux运维 来源:马哥Linux运维 2023-01-06 14:21 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

使用 Promethues 实现应用监控的一些实践

在这篇文章中我们介绍了如何利用 Prometheus 监控应用。在后续的工作中随着监控的深入,我们结合自己的经验和官方文档总结了一些 Metrics 的实践。希望这些实践能给大家提供参考。

确定监控对象

在具体设计 Metrics 之前,首先需要明确需要测量的对象。需要测量的对象应该依据具体的问题背景、需求和需监控的系统本身来确定。

从需求出发

Google 针对大量分布式监控的经验总结出四个监控的黄金指标,这四个指标对于一般性的监控测量对象都具有较好的参考意义。这四个指标分别为:

延迟:服务请求的时间。

通讯量:监控当前系统的流量,用于衡量服务的容量需求。

错误:监控当前系统所有发生的错误请求,衡量当前系统错误发生的速率。

饱和度:衡量当前服务的饱和度。主要强调最能影响服务状态的受限制的资源。例如,如果系统主要受内存影响,那就主要关注系统的内存状态。

以上四种指标,其实是为了满足四个监控需求:

反映用户体验,衡量系统核心性能。如:在线系统的时延,作业计算系统的作业完成时间等。

反映系统的吞吐量。如:请求数,发出和接收的网络包大小等。

帮助发现和定位故障和问题。如:错误计数、调用失败率等。

反映系统的饱和度和负载。如:系统占用的内存、作业队列的长度等。

除了以上常规需求,还可根据具体的问题场景,为了排除和发现以前出现过或可能出现的问题,确定相应的测量对象。比如,系统需要经常调用的一个库的接口可能耗时较长,或偶有失败,可制定 Metrics 以测量这个接口的时延和失败数。

从需要监控的系统出发

为了满足相应的需求,不同系统需要观测的测量对象也是不同的。在 官方文档 的最佳实践中,将需要监控的应用分为了三类:

线上服务系统(Online-serving systems):需对请求做即时的响应,请求发起者会等待响应。如 web 服务器。

离线计算系统(Offline processing):请求发起者不会等待响应,请求的作业通常会耗时较长。如批处理计算框架 Spark 等。

批处理作业(Batch jobs):这类应用通常为一次性的,不会一直运行,运行完成后便会结束运行。如数据分析的 MapReduce 作业。

对于每一类应用其通常情况下测量的对象是不太一样的。其总结如下:

线上服务系统:主要有请求、出错的数量,请求的时延等。

线下计算系统:最后开始处理作业的时间,目前正在处理作业的数量,发出了多少 items, 作业队列的长度等。

批处理作业:最后成功执行的时刻,每个主要 stage 的执行时间,总的耗时,处理的记录数量等。

除了系统本身,有时还需监控子系统:

使用的库(Libraries): 调用次数,成功数,出错数,调用的时延。

日志(Logging):计数每一条写入的日志,从而可找到每条日志发生的频率和时间。

Failures: 错误计数。

线程池:排队的请求数,正在使用的线程数,总线程数,耗时,正在处理的任务数等。

缓存:请求数,命中数,总时延等。

选择 Vector

选用 Vec 的原则:

数据类型类似但资源类型、收集地点等不同

Vec 内数据单位统一

例子:

不同资源对象的请求延迟

不同地域服务器的请求延迟

不同 http 请求错误的计数

此外,官方文档 中建议,对于一个资源对象的不同操作,如 Read/Write、Send/Receive, 应采用不同的 Metric 去记录,而不要放在一个 Metric 里。原因是监控时一般不会对这两者做聚合,而是分别去观测。 不过对于 request 的测量,通常是以 Label 做区分不同的 action。

确定 Label

常见 Label 的选择有:

resource

region

type

确定 Label 的一个重要原则是:同一维度 Label 的数据是可平均和可加和的,也即单位要统一。如风扇的风速和电压就不能放在一个 Label 里。

此外,不建议下列做法:

my_metric{label=a} 1 my_metric{label=b} 6 my_metric{label=total} 7

即在 Label 中同时统计了分和总的数据,建议采用 PromQL 在服务器端聚合得到总和的结果。或者用另外的 Metric 去测量总的数据。

命名 Metrics 和 Label

好的命名能够见名知义,因此命名也是良好设计的一环。

Metric 的命名:

需要符合 pattern: a-zA-Z:

应该包含一个单词作为前缀,表明这个 Metric 所属的域。

如:

prometheus_notifications_total

process_cpu_seconds_total

ipamd_request_latency

应该包含一个单位的单位作为后缀,表明这个 Metric 的单位。

如:

http_request_duration_seconds

node_memory_usage_bytes

http_requests_total (for a unit-less accumulating count)

逻辑上与被测量的变量含义相同。

尽量使用基本单位,如 seconds,bytes。而不是 Milliseconds, megabytes。

Label 的命名:

依据选择的维度命名,如:

region: shenzhen/guangzhou/beijing

owner: user1/user2/user3

stage: extract/transform/load

Buckets 选择

适宜的 buckets 能使 histogram 的百分位数计算更加准确。

理想情况下,桶会使得数据分布呈阶梯状,即各桶区间内数据个数大致相同。
buckets 的设计可遵从如下经验:

需要知道数据的大致分布,若事先不知道可先用默认桶 ({.005, .01, .025, .05, .1, .25, .5, 1, 2.5, 5, 10})或 2 倍数桶({1,2,4,8…})观察数据分布再调整 buckets。

数据分布较密处桶间隔制定的较窄一些,分布稀疏处可制定的较宽一些。

对于多数时延数据,一般具有长尾的特性,较适宜用指数形式的桶(ExponentialBuckets)。

初始桶上界一般覆盖10%左右的数据,若不关注头部数据也可以让初始上界更大一些。

若为了更准确计算特定百分位数,如90%,可在90%的数据处加密分布桶,即减少桶的间隔。

比如我在监控我们某些任务耗时的时候,就是选根据实际情况估算出大致的 bucket 取值,上线后观察数据和监控再去调整 bucket, 这样经过几次调整应该就能调整到比较合适的 bucket。

Grafana 使用技巧

查看所有维度

如果你想知道是否还能按其它维度分组,并快速查看还有哪些维度,可采用以下技巧:在 query 的表达式上只保留指标名称,不做任何计算,Legend format 也留空。这样就能显示出原始的 metric 数据。如下图所示

70392922-8d89-11ed-bfe3-dac502259ad0.png

标尺联动

在 Settings 面板中,有一个 Graph Tooltip 设置项,默认使用 Default。

7062b2d8-8d89-11ed-bfe3-dac502259ad0.png

下面将图形展示工具分别调整为 Shared crosshair 和 Shared Tooltip 看看效果。可以看到标尺能联动展示了,方便排查问题时确认 2 个指标的关联性。

将图形展示工具调整为 Shared Tooltip:

7091a458-8d89-11ed-bfe3-dac502259ad0.png

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 测量
    +关注

    关注

    10

    文章

    5714

    浏览量

    116967
  • Prometheus
    +关注

    关注

    0

    文章

    36

    浏览量

    2072

原文标题:Prometheus Metric 的实践总结,搞定监控需注意~

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Prometheus千节点集群的横向扩展实践

    在2026年的运维环境中,千节点规模的Kubernetes集群已经稀松平常。一个典型的中大型互联网公司,其Kubernetes集群规模通常在3000至5000个节点,单个集群中运行的Pod数量动辄数万个。在这样的规模下,监控系统面临的压力是前所未有的。
    的头像 发表于 03-31 14:37 209次阅读

    EMC PCB设计总结

    EMC PCB设计总结
    发表于 03-23 14:52 13次下载

    使用Prometheus和Grafana的企业级监控落地实战

    生产环境跑着几百台机器,出了故障全靠人肉巡检和用户反馈,这种被动运维的日子我们团队经历了两年。2019年开始全面切换到Prometheus+Grafana体系,到现在稳定运行了五年多,监控覆盖了主机、容器、中间件、业务指标四个层面,日均采集指标点超过2000万。
    的头像 发表于 02-27 10:58 387次阅读

    Prometheus告警规则编写与Alertmanager通知配置实战

    监控系统搭完了,指标也采集上来了,但如果没有告警,等于白搭。我见过不少团队Prometheus跑得好好的,Grafana大屏也挂在墙上,结果凌晨3点数据库磁盘写满了,第二天早上用户投诉才发现。监控不闭环,就是摆设。
    的头像 发表于 02-26 16:35 545次阅读

    使用VictoriaMetrics的Prometheus远程存储方案

    Prometheus单机存储在生产环境跑到一定规模就会碰壁——单节点磁盘容量有限,TSDB默认保留15天数据,想存半年以上的监控数据基本不现实。更麻烦的是Prometheus没有原生的高可用方案
    的头像 发表于 02-26 16:30 388次阅读

    【「Altium Designer 25 电路设计精进实践」阅读体验】总体感受

    非常感谢电子发烧友提供的「Altium Designer 25 电路设计精进实践」读书机会。因为书到的时候已经放假了,所以现在才拿到书。 这本书是陈之炎老师撰写的关于Altium
    发表于 02-22 18:06

    【「Altium Designer 25 电路设计精进实践」阅读体验】+本书概览与内容特点介绍

    ,比较有参考意义。 本书特点:全彩印刷理论结合实践,前面介绍理论,后面介绍实践,尤其是后面的SAM V71可以参考自己做一个类似的开发板。 总结:本书基于AD25介绍电子电路设计,介绍了一些贴近工程
    发表于 02-14 15:56

    2024年度技术总结——MCU与MEMS和TOF应用实践

    认识到,技术的进步不仅仅是理论上的突破,更需要在客户应用场景中进行实践和验证。技术不应仅限于闭门造车,它的真正价值是在实际项目中落地,并为产品赋能,从而解决现实世界中的挑战。 通过对客户项目
    的头像 发表于 12-22 15:04 1427次阅读
    2024年度技术<b class='flag-5'>总结</b>——MCU与MEMS和TOF应用<b class='flag-5'>实践</b>

    国星光电入选“2025年上市公司可持续发展优秀实践案例”

    两年获此殊荣。 中国上市公司协会自2021年起开展上市公司可持续发展(ESG)实践案例征集,旨在总结推广优秀经验,推动上市公司对标对表、互学互鉴,提升可持续发展价值。 近年来,国星光电按照广东省国资委和广晟控股集团的决策部署和工作要求
    的头像 发表于 11-20 19:07 4127次阅读

    Zabbix与Prometheus运维监控系统的对比

    在当今云原生和微服务架构盛行的时代,监控系统已成为运维工程师不可或缺的核心工具。面对市场上众多监控解决方案,Zabbix和Prometheus作为两大主流选择,各自拥有独特的优势和适用场景。本文将从架构设计、性能表现、功能特性、运维成本等多个维度进行深入对比,为你的监控系统选型提供专业指导。
    的头像 发表于 09-18 14:57 813次阅读

    常用PromQL查询案例总结

    在云原生时代,Prometheus已经成为监控领域的事实标准。作为一名资深运维工程师,我见过太多团队在PromQL查询上踩坑,也见过太多因为监控不到位导致的生产事故。今天分享10个实战中最常用的PromQL查询案例,每一个都是血泪经验的总结
    的头像 发表于 09-18 14:54 851次阅读

    如何构建高可用Prometheus监控体系

    在云原生时代,传统监控工具已经无法满足微服务架构的复杂需求。Prometheus凭借其Pull模式、多维数据模型和强大的查询语言PromQL,成为了CNCF毕业项目中的监控标杆。
    的头像 发表于 08-01 09:10 1003次阅读

    【「Yocto项目实战教程:高效定制嵌入式Linux系统」阅读体验】01总结实践记录

    ,运行一下,输入密码之后就跑出来了界面了: 选择terminal看看效果: 看一下文件管理器: 附上书本内容: 四 总结 这本书还是非常不错的,关于Yocto的介绍和首次实践也都成功了,这里
    发表于 06-30 11:38

    相关协议信号总结

    电子发烧友网站提供《相关协议信号总结.xlsx》资料免费下载
    发表于 06-25 15:34 5次下载

    详解Prometheus的数据类型

    对于 Prometheus 生态的监控系统,PromQL 是必备技能,本文着重点讲解这个查询语言,掺杂一些生产实践场景,希望对你有所帮助。
    的头像 发表于 05-13 09:50 1584次阅读
    详解<b class='flag-5'>Prometheus</b>的数据类型