Prometheus连接多个指标

初识PromSQL

PromSQL看起来简短整洁,通俗易懂。乍一看很简单,但是当真正使用它的时候,就会发现Prometheus的语句苍白无力,微不足道。在网上关于PromSQL的博客,问答较少,官网上的教程不是很好看懂,而且大多都是在编程的基础上实验。下面根据公司使用Prometheus的情况就我自身理解来谈谈指标之间的聚合。

一、Prometheus二进制操作符

参考网上文章,PromSQL有15个二进制操作符,可以根据操作类型分为三组:

  1. 算术 + - * / ^ %

  2. 比较< > <= >= == !=

  3. 逻辑and unless or

对于不同类型的操作数,可以看一下具体的例子。

rabbitmq_queue_messages_ready  + rabbitmq_queue_messages_unacked 
rabbitmq_queue_messages_ready + rabbitmq_queue_messages_unacknowledged > 0

一对一匹配One to one

example 1:

在这里插入图片描述

一对多和多对一匹配

一对一的匹配是最直接的匹配。大多数的时候,on或则ignoring有助于返回一些想要的内容,这里的缺陷是。某些查询结果可能只显示一对一的基数。例如,碰巧查询在选定的时间范围内显示了一对一的数据关系,但通常可以是一对多。或则多对一。

Prometheus支持多对一和一对多的匹配。但必须通过向查询添加group_left或group_right修饰来指定。否则可能返回错误。

multiple matches for labels: many-to-one matching must be explicit (group_left/group_right)

除非使用逻辑运算符 and unless or,否则Prometheus总是认为二元运算的至少一边具有1的技术,如果在查询的执行过程中,Prometheus在one端发现冲突(标签冲突)查询将失败,并出现一下错误:

found duplicate series for the match group <keys/values> on the <left|right> hand-side of the operation: <op>;
many-to-many matching not allowed: matching labels must be unique on one side

即使一方没有冲突,指定了group_leftgroup_right,查询仍然失败,报错:

multiple matches for labels: grouping labels must ensure unique matches

会报这个错误是因为prometheus对于多方面的每一个元素,应该只能从一个方面找到一个元素,否则,查询结果将变得不清晰
one to one匹配
在这里插入图片描述
many to one匹配

在这里插入图片描述
many to many

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 我可以為您提供一些有關Nginx Prometheus的資訊:Nginx Prometheus是一個用於監控和記錄Nginx網絡伺服器性能指標的開源工具,它可以提供可視化的报告和警報。它支持多種可配置的監測和記錄功能,可以幫助您更清楚地了解網絡伺服器的運行情況,以及對現有性能的影響。 ### 回答2: nginx是一个开源的高性能HTTP和反向代理服务器,可以用于处理静态和动态内容,支持负载均衡、动态缓存和SSL加密等功能。它具有轻量级和高并发的特点,被广泛应用于构建高可用、高性能的Web服务器集群。 Prometheus是一款开源的监控和报警工具,专注于时序数据的收集和存储。它通过采集HTTP接口、Push Gateway和服务发现等多种方式获取应用程序、操作系统和网络设备的监控数据,并将数据存储在自身的时间序列数据库中。Prometheus还支持创建自定义报警规则,并可通过邮件、PagerDuty等方式发送告警通知。 Nginx和Prometheus之间可以进行集成,用于监控Nginx服务器的运行状态和性能指标。具体来说,可以通过Prometheus的插件或者Prometheus自身提供的Exporter来采集Nginx服务器的指标数据,包括连接数、请求处理时间、响应码等。这些指标数据将被存储在Prometheus的时间序列数据库中,并可以通过PromQL语言进行查询和分析。 通过Nginx和Prometheus的集成,可以实现对Nginx服务器的实时监控和性能分析。例如,通过监控连接数可以及时发现并处理异常请求;通过监控请求处理时间可以优化Nginx服务器的性能;通过监控响应码可以及时发现和解决错误。此外,利用Prometheus的报警功能,还可以设置自定义的告警规则,实现对Nginx服务器健康状态的实时监测和及时报警。 总之,Nginx和Prometheus的结合可以提供强大的监控和报警能力,帮助运维人员实时了解和掌握Nginx服务器的运行状态,及时发现潜在的问题并进行处理,进一步提升服务器的可靠性和性能。 ### 回答3: Nginx是一款开源的高性能Web服务器,具有轻量级且高效的特点。它可以作为Web服务器处理并响应HTTP请求和静态文件的请求。同时,Nginx也可作为反向代理服务器用于负载均衡和缓存加速,在大型网站和应用中被广泛使用。 而Prometheus是一款开源的监控和告警工具。它可以进行指标收集、存储、查询和可视化,并且支持自定义的告警规则。Prometheus是基于拉取的方式,周期性地从被监控的目标(如Nginx服务器)获取数据。通过Prometheus,我们可以实时监控Nginx的性能指标,如网络请求的吞吐量、响应时间、错误率等。如果某个指标超过了预设的阈值,Prometheus会触发告警,并及时通知相关人员。 在Nginx和Prometheus的结合中,我们可以使用Nginx的内置模块ngx_http_stub_status_module来将Nginx性能指标暴露为Prometheus所能接收的格式。通过配置Nginx,我们可以使其将性能指标数据以Prometheus的拉取方式暴露出来,然后由Prometheus进行收集和存储。在Prometheus的配置文件中,我们可以定义要监控的Nginx服务器的地址和特定的指标,以及设置告警规则和查询语句。 通过将Nginx和Prometheus结合起来,我们可以实现对Nginx服务器的实时监控和报警。这有助于及时发现和解决性能问题,提高系统的稳定性和可靠性。同时,Prometheus还提供了丰富的图标化界面,可以方便地查看和分析监控数据,为系统性能优化提供支持。总的来说,Nginx和Prometheus的组合是一种强大的监控和管理解决方案,可以为Web服务器的运维工作提供更好的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Energet!c

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值