当前位置:首页 >知识 >Prometheus 在分布式监控上的实践,运维请收藏 通讯量:监控当前系统的流量

Prometheus 在分布式监控上的实践,运维请收藏 通讯量:监控当前系统的流量

2024-07-02 14:06:57 [百科] 来源:避面尹邢网

Prometheus 在分布式监控上的分布实践,运维请收藏

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

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

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

确定监控对象

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

Prometheus 在分布式监控上的实践,运维请收藏 通讯量:监控当前系统的流量

从需求出发

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

Prometheus 在分布式监控上的实践,运维请收藏 通讯量:监控当前系统的流量

  • 延迟:服务请求的时间。
  • 通讯量:监控当前系统的流量,用于衡量服务的容量需求。
  • 错误:监控当前系统所有发生的错误请求,衡量当前系统错误发生的速率。
  • 饱和度:衡量当前服务的饱和度。主要强调最能影响服务状态的受限制的资源。例如,如果系统主要受内存影响,那就主要关注系统的内存状态。

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

Prometheus 在分布式监控上的实践,运维请收藏 通讯量:监控当前系统的流量

  • 反映用户体验,衡量系统核心性能。如:在线系统的时延,作业计算系统的作业完成时间等。
  • 反映系统的吞吐量。如:请求数,发出和接收的网络包大小等。
  • 帮助发现和定位故障和问题。如:错误计数、调用失败率等。
  • 反映系统的饱和度和负载。如:系统占用的内存、作业队列的长度等。

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

  • prometheus_notifications_total
  • process_cpu_seconds_total
  • ipamd_request_latency
  • 需要符合 pattern: a-zA-Z:
  • 应该包含一个单词作为前缀,表明这个 Metric 所属的域。
    如:
  • 应该包含一个单位的单位作为后缀,表明这个 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 数据。如下图所示

标尺联动

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

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

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

责任编辑:张燕妮 来源: 高效运维 运维应用监控

(责任编辑:焦点)

    推荐文章
    • 新能源板块成为反弹急先锋 板块调整已相对充分

      新能源板块成为反弹急先锋 板块调整已相对充分自今年4月27日大盘创下2863点的年内新低后,逐渐震荡企稳站上3000点,近来新能源板块成为反弹急先锋。期间,新能源主题基金及重仓新能源板块的基金也大幅“回血”。基金经理表示 ...[详细]
    • 四个字的歌曲

      四个字的歌曲前言:答:四个字的歌曲太多了,现给你摘抄几个:周华健的《心如刀割》甄妮的《铁血丹心》张宇的《曲终人散》李晓杰的《朋友的酒》,以下就不在写演唱者了。《爱我中华》爱情转移独家记忆新不了情幸福恋人情非得已从 ...[详细]
    • 2018世界杯德国惨败

      2018世界杯德国惨败前言:世界杯德国队出局败给哪个国家?北京时间6月27日22点比赛中,韩国2:0德国,德国出局,德国队到底怎么了。德国与韩国的比赛,上半场德国控球率占优,但并未将优势转化为得分,整体节奏较为平缓。韩国队 ...[详细]
    • 德胜大大是什么梗

      德胜大大是什么梗连人民日报都用上yyds,这个yyds到底是什么意思?yyds这个词,是一个网络用词,源自于电竞圈。是由曾是一名职业选手现是一名主播的“山泥若”在直播期间随口说出来的。在一次直播的时候,他称英雄联盟职 ...[详细]
    • 碧桂园服务(06098.HK)公布:拟收购蓝光嘉宝服务(02606.HK)64.62%股权 明日复牌

      碧桂园服务(06098.HK)公布:拟收购蓝光嘉宝服务(02606.HK)64.62%股权 明日复牌碧桂园服务(06098.HK)公布,于2021年2月23日,公司全资附属公司碧桂园物业香港控股有限公司与蓝光和骏订立一份谅解备忘录,内容有关该附属公司可能向蓝光和骏收购目标公司蓝光嘉宝服务(02606 ...[详细]
    • 开始胃疼是什么梗

      开始胃疼是什么梗网上说的胃疼是什么梗?1、胃疼剧情,网络流行词,指一些看了使人胃疼的剧情。2、这里的剧情通常指动漫、游戏和其他ACG作品中男主在多个女主之间摇摆不定、无法抉择、我全都要的多角...看白色相簿2里面很多 ...[详细]
    • 薏米可以和绿豆一起煮吗

      薏米可以和绿豆一起煮吗请问薏仁米可以跟一起煮吗?是什么功效?跟黄绿豆能和很有营养的。也可以喝黄豆一起煮。黑芝麻薏米绿豆粉的吃法可以吗?有害吗?薏米具有补益脾胃,利湿的作用。绿豆有一定的清热解毒的作用。意见建议:以上三者可以 ...[详细]
    • 吃醋泡黑豆有什么好处

      吃醋泡黑豆有什么好处醋泡黑豆的醋泡黑豆养生保健食品,具体有以下几种功效:具有降血压、降血脂的功效,可以用于治疗高血压,高血脂,并且可以预防各种心脑血管疾病的发生,例。糖尿病人能吃醋泡黑豆醋泡黑豆是一种养生方法。醋泡黑豆有 ...[详细]
    • 中国中铁一季度经营成果实现“开门红” 大幅超出市场预期

      中国中铁一季度经营成果实现“开门红” 大幅超出市场预期根据最新统计数据,截至今年一季度末,中国中铁累计新签合同额6057.4亿元,同比增长84.0%。其中,基础设施建设业务新签合同额5434.5亿元,同比增长94.1%,大幅超出市场预期。从具体业务板块来 ...[详细]
    • 水灵灵的好女人是什么梗

      水灵灵的好女人是什么梗农村俗语:“男怕柿子女怕梨,母猪最怕西瓜皮”是啥意思?有何...农村俗语是千百年来中国文化长河中孕育出来的一种奇特文化,它虽然难登大雅之堂,但它却深受广大农民朋友的喜爱,因为它是农民朋友,经过长期生活 ...[详细]
    热点阅读