【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

这篇具有很好参考价值的文章主要介绍了【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

1、如果对PromSQL不熟悉可以先看以下链接

https://valyala.medium.com/promql-tutorial-for-beginners-9ab455142085

2、与PromQL相比,以下功能在MetricsQL中的实现方式不同,这也改善了用户体验

2-1、MetricsQL 考虑了方括号中窗口之前的前一个点,用于范围函数,例如速率和增加。这允许返回用户对 increase(metric[$__interval]) 查询期望的准确结果,而不是 Prometheus 为此类查询返回的不完整结果

2-2、MetricsQL不推断范围函数结果,(且考虑方括号中窗口之前的前一个点)使得rate函数更为精确

MetricsQL 有意使 rate 和 increase 的实现略有不同。它考虑了前一个时间间隔的最后一个样本,这允许在计算速率或增加时捕获时间序列中的所有信息:

【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

此外,如果间隔中没有足够的样本用于计算 和 ,MetricsQL 会自动增加方括号中的间隔(也称为后视窗口rate)increase。这解决了放大时出现意外“无数据”错误的问题。

2-3、MetricsQL 在计算rate和increase时不应用外推法。这解决了整数计数器的小数结果问题:

【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

2-4、MetricsQL支持更完善的负偏移

VictoriaMetrics 支持负偏移量,如果启用了特定功能标志, Prometheus 从2.26版开始也支持负偏移量。但是,由于 Prometheus 在额外的 5 分钟内继续使用指标的最后一个值,因此即使使用启用的功能标志,查询结果也不同:

【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

原因:这是因为在获取系列时进行了回溯而不是陈旧,并且它被设置为从查询时间回溯 5m。如果您尝试查询时间为 X 的系列,查询引擎会查找从 X-5m 到 X 的系列并获取最新样本。因此,当您以偏移量 -10m 展望未来时,回溯将找到未来 5m 内的最后一个样本。

相关issue:https://github.com/prometheus/prometheus/discussions/9428

2-5、相比vm,prometheus外推可能带来数据不准确问题:

因为有时候prometheus漏掉了一半的点,然后由于需要外推,就会自动按那个趋势去算,导致以下问题:

下面假设每个点间隔5s,计算间隔10s。1121这种的其实增量1,但是如果外推只取到了中间的数据点1和2,然后根据增量1和只采了一半的数据点来外推乘2倍数,那就是2了,导致错误数据

1-----1-----2------1
   |------|-----|

此时取了中间两个点的增量2-1=1,然后两个点间隔5s,计算间隔又是10s,那就做外推,得到估计的增量是2,就变成了正常数值的2倍,实际就偏差了很多

2-6、MetricsQL支持查询:{name=~“.*”}

PromQL 拒绝这样的查询以防止数据库过载,因为查询会从中选择所有指标。同时,PromQL 不会阻止用户运行几乎相同的查询{name=~“.+”},其目的相同。

2-7、metrics有着比prometheus更大的精度损失

由于使用了压缩算法, VictoriaMetrics 可能会降低超过 15 位小数的值的精度。
虽然这种精度损失在极少数情况下可能很重要,但在大多数实际情况下并不重要,因为测量误差通常比精度损失大得多。

2-8、metricsQL可以省略后视窗口,自动计算

为 Prometheus和在 Prometheus 中选择正确的后视窗口非常重要。否则,可能会返回不正确的数据或不返回任何数据。Grafana甚至引入了一个特殊的变量$__rate_interval来解决这个问题,但它可能会导致比它解决的问题更多的问题:

  • 1、用户需要在数据源设置中配置抓取间隔值才能使其工作;
  • 2、用户仍然需要$__rate_interval手动添加到每个使用的查询rate;
  • 3、如果数据源存储具有不同抓取间隔的指标(例如跨多个数据源的全局视图),它将不起作用;

它仅适用于 Grafana。在 MetricsQL 中,可以省略方括号中的后视窗口。VictoriaMetrics 会根据当前步骤自动选择后视窗口,因此rate(node_network_receive_bytes_total)与rate(node_network_receive_bytes_total[$__interval]). 并且即使间隔太小而无法捕获足够的数据点,MetricsQL 也会自动对其进行扩展。

这就是为什么类似deriv(demo_disk_usage_bytes[1s])Prometheus不返回任何数据,但VictoriaMetrics 的查询会在进行计算之前扩展后视窗口。

2-9、MetricsQL返回step小于scrape interval的rate的预期非空响应结果

rate() 函数为您提供所提供的时间序列的变化率,因此rate(mysql_global_status_questions[10s])基本上会为我们提供过去 10 秒内 MySQL 问题的平均数。到目前为止一切都很好。
但是,如果这个时间序列的分辨率低于 10 秒,例如,如果我们只每分钟测量一次mysql_global_status_questions怎么办?在这种情况下,rate() 函数将不返回任何内容,数据将从图中消失。

MetricsQL在间隔太小而无法捕获足够的数据点时也会自动对其进行扩展

我们查看对于上述情况,prometheus与vm的不同处理方式

【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处

2-10、MetricsQL 将scalar类型视为与不带标签的instant vector相同,因为这些类型之间的细微差别通常会使用户感到困惑

2-11、MetricsQL从输出中移除所有NaN值,因此一些查询(如 (-1)^0.5)在 VictoriaMetrics 中返回空结果,而在 Prometheus 中返回一系列 NaN 值。请注意,Grafana 不会为 NaN 值绘制任何线条或点,因此 VictoriaMetrics 和 Prometheus 的最终结果看起来相同。

2-12、MetricsQL 在应用函数后保留指标名称,这不会改变原始时间序列的含义。例如,min_over_time(foo) 或 round(foo) 在结果中留下 foo 指标名称

PromSQL:

input:min_over_time(foo)
output:{xxx} value

MetricsQL:文章来源地址https://www.toymoban.com/news/detail-476141.html

input:min_over_time(foo)
output:foo{xxx} value

到了这里,关于【博客647】MetricsQL(VictoriaMetrics)和PromQL(Prometheus)的不同之处的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 类和函数的不同之处

    60. 类和函数的不同之处 1. 创建方式不同 函数 可以通过函数表达式或函数声明来创建: 类 则是通过 class 来创建: 2. 对象创建方式不同 通过 函数 创建的对象可以使用函数调用运算符 () 来创建: 而通过 类 创建的对象必须使用 new 运算符来创建: 3. 继承方式不同 在

    2024年02月07日
    浏览(75)
  • 光纤和光缆有何不同之处?

    很多 人 会有这样的疑问,光纤和光缆有何不同之处?主要是因为光纤和光缆这两个名词容易引起混淆。在严格的定义下,光纤和光缆是两种不同的东西,然而在现实生活中,许多人仍然会混淆这两者。为了更好地理解光纤和光缆之间的区别,我们一起来看一下。 1、光纤是一

    2024年02月01日
    浏览(34)
  • SRE 与 DevOps 的不同之处

    尽管网站可靠性工程 (SRE) 理念早在 2003 年就由 Google 的 Ben Treynor Sloss 提出,但其近年来却一直受到追捧。随着 DevOps 实践已经在许多组织中牢固确立,两者之间的冲突是否已经显现?SRE 只不过是一种过时的趋势吗?是 SRE 补充了 DevOps,或者是 DevOps 补充了 SRE?让我们来回顾一

    2024年02月04日
    浏览(36)
  • 科普知识:HTTP vs HTTPS的不同之处

    今天看到一条新闻,说是银联提醒用户注意网站的https前缀: 在识别网络诈骗方面,银联特别提醒任何网购退款均无需提供银行卡密码和CVN2。任何索要短信验证码的行为都是诈骗。在登录网址时,警惕所谓的“安全中心”“认证中心”,不要轻信“低价”购物网站,并警惕通

    2024年02月08日
    浏览(48)
  • 传统交换机当今交换机不同之处分析

    目前市场上的某些交换机号称具有QoS保证,实际上只支持单级别的优先级设置,在逻辑上不形成环路,而一旦出现故障,启用备份链路,在这里拿出来和大家分享一下,希望对大家有用。 我们经常说到的以太网传统交换机实际是一个基于网桥技术的多端口第二层网络设备,它

    2024年02月05日
    浏览(39)
  • ChatGPT和其他自然语言处理模型有什么不同之处?

    ChatGPT是一种基于变压器神经网络的自然语言生成模型,与传统的语言模型和其他自然语言处理模型相比,具有以下几个显著的不同之处: 1.能够生成连贯、长文本 传统的语言模型(如N-gram模型)通常只能生成短文本,而生成长文本时容易出现重复或不连贯的情况。而ChatGPT使

    2024年02月11日
    浏览(43)
  • Web2与Web3开发的不同之处

    Web2是引入交互功能的第二代互联网,也是我们今天所熟悉的。随着Web的不断发展,第三代互联网,也被称为Web3,正处于积极开发中。Web3引入了在区块链上运行的去中心化和无需许可的系统。但是Web2和Web3开发之间有什么区别呢?这对于从Web2转变到Web3的开发者是个契机,不仅

    2024年02月05日
    浏览(39)
  • 【JAVA】数据类型与变量(主要学习与c语言不同之处)

    ✅作者简介:大家好,我是橘橙黄又青,一个想要与大家共同进步的男人😉😉 🍎个人主页:橘橙黄又青-CSDN博客 目标: 1. 字面常量 2. 数据类型 3. 变量 在上节课 HelloWorld 程序中, System.Out.println(\\\"Hello World\\\") ; 语句,不论程序何时运行,输出的都是 Hello World,其实 \\\"Hello Wo

    2024年03月28日
    浏览(46)
  • TDSCDMA和TDLTE有什么区别 SCDMA和LTE不同之处

    最近,关于TD-SCDMA的话题很多。观点无非就是支持和反对两派,大有清算历史旧账之势。个人以为,TD-SCDMA本身确实是失败的,至少群众的眼睛是雪亮的。但也不能完全否定了TD-SCDMA的功劳,它是不是TD-LTE发展壮大的关键,不好说,但至少为TD-LTE奠定了一个基础。 否定TD-SCDMA之

    2024年02月07日
    浏览(44)
  • ARM-Linux开发与MCU开发的不同之处分析

    目录 一、ARM-Linux应用开发和单片机开发的不同 二、Arm-Linux基本开发环境 针对ARM-Linux程序的开发,主要分为三类:应用程序开发、驱动程序开发、系统内核开发。针对不同种类的软件开发,有其不同的特点。 今天,我们来看看ARM-Linux开发和MCU开发的不同点,以及ARM-Linux的基本

    2024年02月10日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包