Promethues Metrics
Metrics
Metrics可分为三部分:


- HELP 描述metric作用
- TYPE metric类别
TYEP
Counter
- 某个事件发生的次数
- 数字只能增长
Total reuqests
Total Exceptions
Gauge
- 描述当前值
- 可以上升或下降
CurrentCPU Utilization
Available System Memory
Number of concurrent requests
Histogram
- 持续时间或增长值
- 根据配置的bucket sizes进行分组
Response Time
Request Size
Summary
- histograms的简化
- 低于某个值的百分比进行分组
Response Time
Request Size
所有metric默认分配两个labels(instance/job)

Monitoring Containers
- Metrics可以从容器化环境抓取
- Docker Engine Metrics
- 容器Metrics使用cAdvisor
Ubuntu安装Docker
# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl -y
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc# Add the repository to Apt sources:
echo \"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
# 暴露9323端口
sudo vi /etc/docker/daemon.jsoncat /etc/docker/daemon.json
{ "metrics-addr": "127.0.0.1:9323","experimental": true
} sudo systemctl restart docker

bob@ubuntu-host ~ ➜ sudo vi /etc/prometheus/prometheus.yml # 新增job去抓取metricbob@ubuntu-host ~ ➜ tail -n 4 /etc/prometheus/prometheus.yml - job_name: 'docker'scrape_interval: 5sstatic_configs:- targets: ['localhost:9323']bob@ubuntu-host ~ ➜ sudo systemctl restart prometheus.service
进入UI查看

Run cAdvisor
VERSION=v0.49.1 # use the latest release version from https://github.com/google/cadvisor/releases
sudo docker run \--volume=/:/rootfs:ro \--volume=/var/run:/var/run:ro \--volume=/sys:/sys:ro \--volume=/var/lib/docker/:/var/lib/docker:ro \--volume=/dev/disk/:/dev/disk:ro \--publish=8888:8080 \--detach=true \--name=cadvisor \--privileged \--device=/dev/kmsg \gcr.io/cadvisor/cadvisor:$VERSIONcurl localhost:8888/metrics# 配置文件
bob@ubuntu-host ~ ✖ sudo vi /etc/prometheus/prometheus.ymlbob@ubuntu-host ~ ➜ tail -n 4 /etc/prometheus/prometheus.yml- job_name: 'cAvisor'scrape_interval: 5sstatic_configs:- targets: ['localhost:8888']bob@ubuntu-host ~ ➜ sudo systemctl restart prometheus.service

| 指标类型 | Docker Engine Metrics | cAdvisor Metrics |
|---|---|---|
| Docker 使用的 CPU 量 | 监控 Docker 守护进程本身消耗的 CPU 资源 | 不提供 |
| 失败的镜像构建次数 | 记录失败的镜像构建次数 | 不提供 |
| 处理容器操作的时间 | 监控 Docker 执行容器操作(如启动、停止)所需的时间 | 不提供 |
| 针对单个容器的指标 | 没有针对单个容器的详细指标 | 提供详细的容器级别指标,包括 CPU、内存、磁盘 I/O、网络等 |
| 每个容器的 CPU 和内存使用情况 | 不提供 | 监控每个容器消耗的 CPU 和内存资源 |
| 容器内部进程运行情况 | 不提供 | 提供每个容器内正在运行的进程信息 |
| 容器数量 | 不提供 | 显示当前运行的容器数量 |
| 容器的运行时间 | 不提供 | 监控每个容器自启动以来的运行时间 |
| 按容器分配的详细指标 | 不提供 | 提供每个容器的详细资源使用指标,包括 CPU、内存、磁盘 I/O、网络流量等 |
- Docker Engine Metrics:侧重于全局监控和 Docker 守护进程的性能。
- cAdvisor Metrics:侧重于详细的每个容器的资源使用和运行情况,适合细粒度的容器监控。
PromQL
Data Types
PromQL(Prometheus Query Language)的查询语句可以评估为四种不同的类型,分别是:
-
String 字符串值,通常在 Prometheus 的表达式中很少使用。
-
Scalar 简单的数值(浮点型),代表一个特定的数值,比如一个计算结果或常量。
-
Instant Vector 时间序列的集合,每个时间序列只包含一个样本,这些样本都共享相同的时间戳。通常用于查询特定时间点的度量值。

-
Range Vector 时间序列的集合,每个时间序列包含一段时间内的数据点。用于查询一段时间范围内的度量值,如计算平均值或峰值等。

Labels

- = 精确匹配

- != 精确不等匹配

- =~正则匹配

- !~正则不相等匹配

- 多条件匹配

- 区间向量

相关文章:
Promethues Metrics
Metrics Metrics可分为三部分: HELP 描述metric作用TYPE metric类别 TYEP Counter 某个事件发生的次数数字只能增长 Total reuqests Total ExceptionsGauge 描述当前值可以上升或下降 CurrentCPU Utilization Available System Memory Number of concurren…...
公网IP与私网IP具体有哪些区别?
1.接入方式不同 公网IP以公网连接Internet上的非保留地址,私网IP则是局域网上的IP,通过NAT才能够与公网进行通信。 2.特点不同 公网IP由国际互联网络信息中心InterNIC负责,将IP地址分配给注册并向InterNIC提出申请的机构或组织。私网IP则是为节省可分配…...
LeetCode——3143. 正方形中的最多点数
通过万岁!!! 题目:给你一个n*2的数组,然后第i行表示第i个点的坐标,然后还给你了一个字符串s,s[i]则表示第i个点的名称。然后让你找一个中心是(0,0)的正方形,…...
const重新赋值的问题
问: const haveNextPage false; // 默认没有下一页fetch(historyFullUrl).then(data > {haveNextPage data.data.has_more;这段代码有什么问题吗? 回答: 在你的代码中,有一个潜在的问题涉及到 haveNextPage 的赋值。你定义了 haveNextPage 作为一个常量&am…...
python开发上位机 - PyCharm环境搭建、安装PyQt5及工具
目录 简介: 一、安装PyCharm 1、下载 PyCharm 2、PyCharm安装 1)配置安装目录 2)安装选项 3、问题及解决方法 二、安装PyQt5 1、打开 Pycharm,新建 Project 2、安装 pyqt5 3、安装很慢怎么办? 4、安装 pyq…...
day02-安装虚拟机
1. 安装配置 前面一直下一步就OK 2. 虚拟机操作系统配置 语言 中文 软件安装: 最小安装,标准,调试工具,开发工具,系统工具,man手册 网络和主机名配置 主机名,自己起名字 网络配置 常规 &g…...
Qt:线程
一个Qt窗口生成后,为什么拖动窗口,窗口可以随着鼠标移动或放大缩小 因为对窗口操作后,都有对应的事件产生,Qt在其框架中对这些事件进行了默认处理 一个Qt程序默认只有一个线程,称为主线程(也叫ui线程&#…...
VisionPro二次开发学习笔记11-使用 Caliper和Fixture定位Blob工具检测方块
该示例演示了如何使用卡尺工具和夹具工具来固定 Blob 工具。示例代码将检测图像上部区域中小方块的存在。当点击“运行”按钮时,将读取一张新图像。卡尺工具将被运行,卡尺工具的输出 Y 信息将传递给夹具工具。夹具工具使用来自卡尺工具的 Y 信息和新图像…...
高翔【自动驾驶与机器人中的SLAM技术】学习笔记(五)卡尔曼滤波器一:认知卡尔曼滤波器;协方差矩阵与方差;
卡尔曼滤波器 为了研究卡尔曼,我阅读了大量博文。不敢说完全吃透,但是在做一件什么事,可以通过下面这文章来理解,我读了不下五遍。并整理标准重点,添加自己的一些见解。 自动驾驶传感器融合算法 - 自动驾驶汽车中的激…...
【Go】通过反射解析对象tag信息,实现简易ORM
反射是运行时,需要在运行时解析类型信息,编译期无法优化这些操作,因此比编译时已知类型信息的直接调用效率要低。 package mainimport ("fmt""reflect""strings" )type Person struct {Name string json:&quo…...
gemini2相机和宇树雷达L1的使用注意点
gemini2相机: 官方资料:Gemini2深度相机 (yahboom.com) 目前深度这一块智能提供某一点的深度数据,没有提供某一点的世界坐标,虽然网上有文章说是可以计算 已知深度图,获得某个像素点的三维坐标_深度图如何知道特征点的3d坐标-CS…...
FPGA开发——verilog随机涵数$random的使用方法
一、概述 我们进行FPGA开发的过程中在做仿真的时候,难免会需要一些数据作为输入。有的时候需要输入大量的数据对于设计结果进行一个验证,如果逐个去进行输入,就需要花费大量的时间。这种情况下我们通常会想到使用随机数。随机数在我们的日常…...
Android14 WPA2和WPA3 类型的WiFi网络连接
Android14 WPA2和WPA3 类型的WiFi网络连接 文章目录 Android14 WPA2和WPA3 类型的WiFi网络连接一、前言二、源码分析1、Android原生Settings 连接WPA 和WPA3 网络的配置代码 三、其他1、WPA/WPA2和WPA3连接小结2、WPA配置无法连接WPA3的网络的情况Android11 Wifi 加密类型详解 …...
24/8/5算法笔记 逻辑回归sigmoid
今日是代码对sigmoid函数的实现和运用 #linear_model线性回归 #名字虽然叫逻辑回归,作用于分类 #分类:类别 #回归:预测 from sklearn.linear_model import LogisticRegression 实现函数 import numpy as np import matplotlib.pyplot as pl…...
适用于验证码的OCR,识别快速,使用简单!
环境 windows 11python 3.9 前言 Muggle OCR 是一个高效本地 OCR 模块,旨在通过简单的几步设置提供强大的文本识别功能,无论是在处理印刷文本还是解析验证码,都能让用户在工作中畅通无阻。Muggle OCR 易于安装和使用,支持双模型&a…...
超简单适合练手的双指针题:判断子序列
给定字符串 s 和 t ,判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子序列&#…...
打破老美垄断,潘展乐商业价值起飞
文|琥珀食酒社 作者 | 积溪 奥运会上的潘展乐 真是牛逼坏了 拿下男子100米自由游金牌 打破欧美长达近百年垄断 搞定男子4x100米混合泳金牌 终结了美国在这项目上 10年不败的神话 比赛前 美国选手对他爱答不理 招呼都不打 比赛后美国选手想套热乎 潘展乐…...
java面试题:简化URL
1 问题场景 编写一种方法,将字符串中的空格全部替换为%20。假定该字符串尾部有足够的空间存放新增字符,并且知道字符串的“真实”长度。 注意:字符串长度在 [0, 500000] 范围内。 2 答案 2.1 解决方案一 直接使用String方法解决 public s…...
用 echarts 开发地图、点击展示自定义信息框
1、下载所需地市的json 链接:DataV.GeoAtlas地理小工具系列 在右侧输入需要的名称,然后下载json文件到本地 2、在html 中准备容器,并设置宽高 <div id"mapContent"> <div ref"mapChart" style"width:10…...
Android 应用兼容性变更调试
引言 本文将介绍如何调试和解决这些兼容性问题,并记录调试过程中实际操作的步骤和方法。在Android应用开发中,随着Android系统版本的不断更新,应用的兼容性问题变得越来越复杂。 推荐:《Android系统开发中高级定制专栏导读》08-03 16:04:53.518 6555 6555 D Compatibili…...
差动保护:电力系统的核心安全保障技术
差动保护电流差动保护是电力系统的"铁闸门",核心思想简单粗暴:比较设备两端的电流是否对得上账。就像两个会计同时记账,如果两边数据差太多,肯定有人搞鬼——要么线路漏电,要么设备内部短路。举个接地气的例…...
从作业到考试:中科大数字图像分析(DIA)课程避坑与自学指南
中科大数字图像分析(DIA)课程高效学习与实战避坑指南 数字图像分析(DIA)作为中科大电子工程与信息科学系的专业基础课,以其知识面广、难度高著称。每年都有不少同学因低估课程强度而陷入"上课听不懂、作业不会做、考前突击难"的困境。本文将系统梳理从日常…...
前端开发中的加载指示器(Loading Spinners)一种动态旋转的图形元素(如圆圈、齿轮状动画)
在 Android 中,Spinner 是一个下拉选择控件,用于从预定义列表中选择一项。以下是标准、稳定、兼容性好的实现方式(基于 ViewBinding ArrayAdapter,适配 AndroidX 和 API 21):✅ 一、绑定数据(以…...
心理医生哪家强?真实就诊指南+案例分享
行业痛点分析当前长沙心理诊疗领域面临多重技术挑战。数据显示,长沙市精神障碍患病率约为17.5%,其中焦虑、抑郁类障碍占比达62%,但实际就诊率不足30%。测试显示,三甲医院心理科平均排队时间超过45天,单次就诊时长不足1…...
外贸站点SEO优化中如何处理站点的内容优化
外贸站点SEO优化中如何处理站点的内容优化 在当今全球化的商业环境中,外贸站点的SEO优化显得尤为重要。一个成功的外贸站点不仅要吸引国际客户,还需要在搜索引擎结果中获得高排名,以最大限度地提高曝光率和转化率。内容优化是外贸站点SEO优化…...
影墨·今颜多模态应用:结合文本与图像输入的进阶生成案例
影墨今颜多模态应用:结合文本与图像输入的进阶生成案例 最近在玩一个挺有意思的模型,叫影墨今颜。它最吸引我的地方,不是单纯的文生图或者图生图,而是能把文字和图片“揉”在一起,生成一些意想不到的新东西。这感觉就…...
AI辅助开发:让快马AI帮你构思vc16188视频目标识别代码框架
最近在做一个视频分析的小项目,需要实现目标识别功能。作为一个独立开发者,面对复杂的计算机视觉算法确实有点头疼。好在发现了InsCode(快马)平台的AI辅助开发功能,帮我快速搭建起了vc16188视频目标识别的代码框架。这里分享一下我的实现过程…...
别再只问原理了!用Spring Cloud Gateway + Redis手把手搭建分布式令牌桶限流(附完整配置)
实战指南:Spring Cloud Gateway与Redis构建分布式令牌桶限流系统 微服务架构下,流量管控如同城市交通信号灯——没有合理的红绿灯设计,再宽阔的道路也会陷入瘫痪。最近在帮一家跨境电商平台重构网关层时,我们仅用Spring Cloud Gat…...
Qwen3.5-9B-AWQ-4bit与Claude对比评测:开源与闭源模型的技术选型
Qwen3.5-9B-AWQ-4bit与Claude对比评测:开源与闭源模型的技术选型 1. 评测背景与目标 在AI大模型领域,开源与闭源模型的选择一直是开发者面临的重要决策。本次评测聚焦于两款在开发者社区中备受关注的模型:开源的Qwen3.5-9B-AWQ-4bit和闭源的…...
深入解析XSpiPs_PolledTransfer与XSpiPs_Transfer的片选信号行为差异
1. 从波形图看片选信号的关键差异 第一次用逻辑分析仪抓取SPI波形时,我被XSpiPs_PolledTransfer和XSpiPs_Transfer的片选信号差异惊到了。同样是发送两个字节的数据,前者像老式电报机一样稳定保持CS低电平,后者却像发摩尔斯电码似地频繁跳变。…...
