PromQL“where”子句

问题描述

如何在 PromQL 中添加 where 子句?

我正在尝试构建一个查询,当在 Kubernetes 中运行的应用程序启动超过一分钟时显示查询,但我想按命名空间进行过滤。

这是我目前查询的样子

100 * (count(up == 1) BY (job,namespace,service) ) > 1

这工作正常,但它提供了我不需要的额外信息。

{job="prometheus-grafana",namespace="monitor",service="prometheus-grafana"}
{job="jenkins",namespace="jenkins",service="jenkins"}
{job="kube-state-metrics",service="prometheus-kube-state-metrics"}
{job="node-exporter",service="prometheus-prometheus-node-exporter"}
{job="kubelet",namespace="kube-system",service="prometheus-kube-prometheus-kubelet"}
{job="apiserver",namespace="default",service="kubernetes"}

我想要完成的是仅获取 jenkinsdefault 命名空间的结果。

{job="apiserver",service="kubernetes"}
{job="jenkins",service="jenkins"}

我尝试过

100 * (count(up == 1) BY (job,service) ) > 1 and ON {namespace="jenkins"}

但我收到一个 invalid parameter "query": 1:65: parse error: unexpected "{" in grouping opts,expected "(" 错误

解决方法

在您的情况下,您必须通过所需的标签(命名空间)“向上”过滤指标,它应该如下所示:

100 * count(up{namespace=~"default|jenkins"} == 1) > 1
,
  • 你也可以试试这个。在 Kubernetes 中,所有资源都使用 pod。因此,如果您采用 pod 状态指标并将当前时间减去 60,则得出 1 分钟后的 pod 运行状态。

time()-60 > (kube_pod_start_time)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...