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

2024-01-01 12:40

本文主要是介绍使用 Promethues 实现应用监控的一些实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

975aaa30f51178aaaef42be019fbe01c.png

在这篇文章[1]中我们介绍了如何利用 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 里。

d5ec9bae7ab2456a995d91af1197c543.png

点击上方图片,打开小程序,『饿了么外卖』红包天天免费领!

此外,不建议下列做法:

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 数据。如下图所示

37085bb98a9303f1de5e88be739c761e.png

标尺联动

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

4fc92d48bc84cc1e22968845508cf048.png

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

342f87fe45f0a30dbe9b09845a04741c.png

引用链接

[1]

文章: https://www.lxkaka.wang/app-metrics/

原文链接:https://lxkaka.wang/metrics-best-practice/

本文转载自:「云原生实验室」,原文:https://tinyurl.com/zr9wezcr,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

bcf4709d82698d3cf86c099ff6312eb2.gif

06205382e68b7aeea0ecb137517554eb.png

你可能还喜欢

点击下方图片即可阅读

1d1d70a1eb8fe018bdec1f497abc053f.png

如何优雅的通过 ApiServer 远程访问 Kubernetes 集群

53e769fd5de65bf554fe1ea485a608e6.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

ad4b8a270d74291ec920e582d5160bfc.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

这篇关于使用 Promethues 实现应用监控的一些实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/559274

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个