如何解决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"}
我想要完成的是仅获取 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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。