【Prometheus】PromQL

数据类型

  1. 即时向量(instant vector)

node_cpu_seconds_total{instance="ahoj-dev-ubuntu-virtualbox",mode="idle"}
image.png

  1. 区间向量(range vector)

node_cpu_seconds_total{instance="ahoj-dev-ubuntu-virtualbox",mode="idle"}[1m]
image.png

  1. 标量(scalar)

2 * 4
image.png

  1. 字符串(string)

image.png

时间序列过滤器

  1. 瞬时向量过滤器

过滤器标签支持两种模式:完全匹配和正则匹配,正则匹配使用 Google RE2语法
=:完全相同
!=:不相同
=~:选择与提供的正则表达式相匹配的标签
!~:选择与提供的正则表达式不匹配的标签
例如:node_cpu_seconds_total{mode=~"user|system",cpu="0"}
image.png

  1. 区间向量过滤器

以当前时间为基准,查询时间范围内的数据
时间范围通过数字表示,时间单位有s, m, h, d, w, y
例如:node_cpu_seconds_total{mode=~"user|system",cpu="0"}[30s]查询的是 30s 内的数据
image.png

  1. 时间位移操作

如果想查询昨天一天的区间内的数据,需要使用时间位移关键字offset
例如:node_cpu_seconds_total{mode=~"user|system",cpu="0"} offset 3m
这里的offset关键字要跟在选择器{}后面
正确示例:max(node_cpu_seconds_total{mode=~"user|system",cpu="0"} offset 3m)
错误示例:max(node_cpu_seconds_total{mode=~"user|system",cpu="0"}) offset 3m
时间位移操作适用于区间向量,例如:查询一周之前的 5分钟之内的 cpu用户态使用率
rate(node_cpu_seconds_total{instance="ahoj-dev-ubuntu-virtualbox",mode="user"}[5m] offset 1w)

操作符

官方文档:https://prometheus.io/docs/prometheus/latest/querying/operators/

数学运算符

+, -, *, /, %, ^(幂运算)

布尔运算符

查询请求数大于20的:prometheus_http_requests_total > 20
将请求数大于20的结果置为 True,其他置为 False:prometheus_http_requests_total > bool 20
image.png

集合运算符

and(交集), or(并集), unless(排除)
unless:vector1 和 vector2 进行 unless 操作,会产生一个新的集合,该集合首先取 vector1 集合的所有元素,然后排除掉所有 vector2 中存在的元素。
例如:vector1 = [a, b, c], vector2 = [b, c, d] 那么 vector1 unless vector2 = [a]

操作符优先级

  1. ^
  2. *, /, %, atan2
  3. +, -
  4. ==, !=, <=, <, >=, >
  5. and, unless
  6. or

聚合运算

  • sum (calculate sum over dimensions,求和)
  • min (select minimum over dimensions,最小值)
  • max (select maximum over dimensions, 最大值)
  • avg (calculate the average over dimensions,平均值)
  • group (all values in the resulting vector are 1,)
  • stddev (calculate population standard deviation over dimensions,标准差)
    • 常用来描述数据的波动大小,反应一组数据偏离平均值的程度
    • 例如:统计两个球队队员身高,两只对位平均身高都是 180,看起来似乎差不多,但画图如下

image.png
image.png

  • stdvar (calculate population standard variance over dimensions,标准方差)
  • count (count number of elements in the vector,计数)
  • count_values (count number of elements with the same value,对value进行技术)
  • bottomk (smallest k elements by sample value,后n条时序)
  • topk (largest k elements by sample value,前n条时序)
    • topk(5, prometheus_http_requests_total)
  • quantile (calculate φ-quantile (0 ≤ φ ≤ 1) over dimensions,分位数)

内置函数

https://prometheus.io/docs/prometheus/latest/querying/functions/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/735322.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

手拉手RocketMQ基础

消息中间件的对比 消息中间件 ActiveMQ RabbitMQ RocketMQ kafka 开发语言 java erlang java scala 单击吞吐量 万级 万级 10万级 10万级 时效性 ms us ms ms 可用性 高(主从架构) 高(主从架构) 非常高(主从架构) 非常高(主从架构) 消息中间件: activ…

MetaGPT部分源码解读

Action SerializationMixin&#xff1a; Pydantic在序列化一个对象时&#xff0c;会将其序列化为其最顶层父类的形式&#xff0c;而不是它实际子类的形式。这意味着&#xff0c;如果你有一个父类和一个继承自该父类的子类&#xff0c;当你将子类的实例序列化时&#xff0c;得到…

HTTP常见报错响应码

HTTP 响应状态代码指示特定 HTTP 请求是否已成功完成。响应分为五类&#xff1a; 信息响应成功响应重定向客户端错误服务器错误 1 、信息响应 100 Continue 这个临时响应表明&#xff0c;迄今为止的所有内容都是可行的&#xff0c;客户端应该继续请求&#xff0c;如果已经完 …

云上攻防-云产品篇堡垒机场景JumpServer绿盟SASTeleport麒麟齐治

知识点 1、云产品-堡垒机-产品介绍&攻击事件 2、云产品-堡垒机-安全漏洞&影响产品 章节点&#xff1a; 云场景攻防&#xff1a;公有云&#xff0c;私有云&#xff0c;混合云&#xff0c;虚拟化集群&#xff0c;云桌面等 云厂商攻防&#xff1a;阿里云&#xff0c;腾讯…

k8a 对外服务(ingress)详解(定义,暴露,代理,重写,)

目录 一、 对外服务 service策略的作用 外部访问方案 适用场景和限制 ingress如何实现对外服务 ingress 概念 定义 组成 工作原理 总结 二、 部署 nginx-ingress-controller 创建 ingress-controller pod及相关资源 创建目录&#xff1a; 下载配置文件 修改 集群…

CSS拖曳盒子案例

让我为大家带来一个小案例吧&#xff01; <!DOCTYPE html> <html><head><meta charset"utf-8"><title></title><style>* {margin: 0;padding: 0;}.box1 {width: 100px;height: 100px;background-color: black;margin-bot…

iMazing3 2024详细解析数据备份与恢复备份

iMazing 3的备份功能支持增量备份&#xff08;类似苹果电脑里的Time Machine功能&#xff09;&#xff0c;意思是第一次把移动设备的数据全部备份下来&#xff0c;之后的备份就只针对数据有变化的那部分&#xff0c;这样可以节省大量的时间和存储空间&#xff0c;不会让使用者为…

LeetCode59:螺旋矩阵Ⅱ

题目描述 给你一个正整数 n &#xff0c;生成一个包含 1 到 n2 所有元素&#xff0c;且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;[[1,2,3],[8,9,4],[7,6,5]] 代码 class Solution { public:vector…

00-ESP-IDF 环境配置指南

ESP-IDF 环境配置指南 ESP-IDF安装 1.首先我们在浏览器搜索esp-idf&#xff0c;点击第一个选项 2.点击右边栏的安装 3.我们选择手动安装选择需要的系统版本 4.点击链接 5.这里我们选择一个版本&#xff0c;建议不要选择最新的&#xff0c;安装出现问题在网上不好找到解决办…

蓝桥杯备战刷题-滑动窗口

今天给大家带来的是滑动窗口的类型题&#xff0c;都是十分经典的。 1&#xff0c;无重复字符的最长子串 看例三&#xff0c;我们顺便来说一下子串和子序列的含义 子串是从字符串里面抽出来的一部分&#xff0c;不可以有间隔&#xff0c;顺序也不能打乱。 子序列也是从字符串里…

Vue+SpringBoot打造个人健康管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 健康档案模块2.2 体检档案模块2.3 健康咨询模块 三、系统展示四、核心代码4.1 查询健康档案4.2 新增健康档案4.3 查询体检档案4.4 新增体检档案4.5 新增健康咨询 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpri…

【周总结周末日常】

周总结 完成任务开发并且与前端联调通过 完成已开发功能的冒烟测试 修复测试中出现的一些数据显示问题 2024/3/10 晴 温度适宜 这周天气比上周好多了&#xff0c;最起码见到好几次太阳 周六在世纪公园溜达一会儿&#xff0c;偶尔呼吸下大自然&#xff0c;挺棒的…

[2023年]-hadoop面试真题(二)

[2023年]-hadoop面试真题(一) &#xff08;北京&#xff09; Maptask的个数由什么决定?&#xff08;北京&#xff09; 如何判定一个job的map和reduce的数量 ?&#xff08;北京&#xff09; MR中Shuffle过程 ?&#xff08;北京&#xff09; MR中处理数据流程 ?&#xff08;…

c++深拷贝和浅拷贝的区别

在 C 中&#xff0c;深拷贝&#xff08;deep copy&#xff09;和浅拷贝&#xff08;shallow copy&#xff09;是与对象拷贝相关的概念 浅拷贝&#xff08;Shallow Copy&#xff09;&#xff1a; 浅拷贝是指将一个对象的值复制到另一个对象&#xff0c;但如果对象中包含指针成…

【QT】创建第一个QT程序

下面的前7个可以先不看&#xff0c;直接从8开始看 1. 创建Qt程序 一个Qt程序的组成部分&#xff1a;应用程序类&#xff0c;窗口类应用程序类个数&#xff1a;有且只有一个QApplication a;如何查看类对应的模块&#xff1a;光标移动到类上&#xff0c;F1qmake模块的名字 2. …

Redis的主从、哨兵、集群模式的概念及搭建步骤

主从复制 主从模式也叫主从复制&#xff0c;主是主服务器&#xff0c;从是从服务器&#xff0c;主服务器&#xff08;master &#xff09;的数据如果更新了 也会同步到从服务器&#xff08;slave&#xff09;&#xff0c;一个主服务器可以搭配很多个从服务器&#xff0c;主服务…

【设计模式】(四)设计模式之工厂模式

1. 工厂模式介绍 工厂模式&#xff08;Factory Pattern&#xff09;是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。 工厂模式有三种实现方式&#xff1a; 简单工厂模式工厂方法模式抽象工厂模式 2. 工厂方…

前后端分离项目,如何解决跨域问题?

跨域问题是前后端分离项目中非常常见的一个问题&#xff0c;举例来说&#xff0c;编程猫学习网站的前端服务跑在 8080 端口下&#xff0c;后端服务跑在 9002 端口下&#xff0c;那么前端在请求后端接口的时候就会出现跨域问题。 403 Forbidden 是HTTP协议中的一个状态码&#x…

华容道问题求解_详细设计(五)之hash值和回放功能

&#xff08;续上文&#xff09; 布局的hash 值计算 笔者也参考了之前的一些文章&#xff0c;很多文章提到了怎么节省存贮空间来查找最优解&#xff0c;这不是笔者的目的。笔者的目的比较单一&#xff0c;就是找到最优解就行了。因此并没有在存贮上面进行过多的优化&#xff…

Linux系统adb调试小米手机调试不成功出现Exception occurred while executing ‘put‘:问题解决

参考文章&#xff1a;执行android settings命令报错原因Exception occurred while executing put: java.lang.SecurityException: Pe... - 简书 (jianshu.com) 解决Android U无法通过adb安装应用(Caller has no access to session -1)的问题_performing streamed install-CSDN…