问题描述
如何在 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"}
我想要完成的是仅获取 jenkins
和 default
命名空间的结果。
{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)