我想比较以下两个彼此不同的时间序列。我想要做的就是将 第二时间系列 的结果除以 第一时间系列 的结果如果值小于1,则生成警报。我使用的查询低于我在下面提到的时间序列。如何实现我的目标?
第一次系列:
container_memory_usage_bytes {CONTAINER_NAME ="文档"}
结果:
container_memory_usage_bytes{
beta_kubernetes_io_arch="amd64",
beta_kubernetes_io_fluentd_ds_ready="true",
beta_kubernetes_io_instance_type="n1-highmem-8",
beta_kubernetes_io_os="linux",
cloud_google_com_gke_nodepool="pool-1",
container_name="documentation",
failure_domain_beta_kubernetes_io_region="europe-west1",
failure_domain_beta_kubernetes_io_zone="europe-west1-b",
id="/kubepods/burstable/podb79239ff-1ee9-11e8-a6c1-42010a840fd9/3ccdaa6597d5bd306d228e37d9d4c65a9681dba2e894aa7b7ed4502ec54e5619",
image="gcr.io/ingenious-169318/publicapi/documentation@sha256:60a5454bb40ed34f24cbeb9f330e1097191754cf2890eee1ca4f2988188a7705",
instance="gke-ingenious-pool-1-bbd77706-5rbz",
job="kubernetes-cadvisor",
kubernetes_io_hostname="gke-ingenious-pool-1-bbd77706-5rbz",
name="k8s_documentation_documentation-6c4c4c9f5f-dn2bv_apimanager_b79239ff-1ee9-11e8-a6c1-42010a840fd9_0",
namespace="apimanager",
pod_name="documentation-6c4c4c9f5f-dn2bv"
}
第二期系列: -
kube_pod_container_resource_requests_memory_bytes {容器="文档"}
结果:
kube_pod_container_resource_requests_memory_bytes{
container="documentation",
instance="10.32.0.30:8080",
job="kubernetes-service-endpoints",
k8s_app="kube-state-metrics",
kubernetes_name="kube-state-metrics",
kubernetes_namespace="kube-system",
namespace="apimanager",
node="gke-ingenious-pool-1-bbd77706-pdsz",
pod="documentation-6c4c4c9f5f-mzd54"
}
PromQL:
kube_pod_container_resource_requests_memory_bytes {container =" documentation"} /(container_memory_usage_bytes {namespace =" apimanager"})
答案 0 :(得分:3)
向量匹配
Prometheus将此称为Vector Matching,如果它们的标签匹配,则可以跨不同的时间序列执行算术二进制运算(+,-,*,/等)。如果它们不匹配,则可以使用on
或ignoring
选择应该匹配的标签。
一对一地从 操作。在默认情况下,这是遵循 格式化vector1 vector2。如果两个条目具有 完全相同的一组标签和相应的值。无视 关键字允许匹配时忽略某些标签,而on 关键字允许将考虑的标签集减少到提供的 列表
例如
kube_pod_container_resource_requests_memory_bytes{container="documentation"}
/ on (container)
container_memory_usage_bytes{namespace="apimanager"}
label_join / label_replace
在您的特定示例中,没有可以与on
匹配的标签。 container_memory_usage_bytes
有container_name
,而kube_pod_container_resource_requests_memory_bytes
有container
。 Prometheus还有其他名为label_join和label_replace的查询功能,可让您在其中一个指标上创建自定义标签。
在您的情况下,您可能需要使用label_replace将_name
附加到kube_pod_container_resource_requests_memory_bytes
。这样,您就可以使用/ on (container_name)
了,如上所示。
希望这两个普罗米修斯概念,向量匹配和label_join / replace将帮助您跨不同的时间序列执行算术运算。注意:我对您的确切用例还不够熟悉,无法知道container_name
是用于实现所需输出的最佳标签,还是使用Kubernetes和Prometheus可以更简单地实现这一目标。