4

最终在带有 Prometheus 和 Grafana 的 Docker 环境中运行 Harvest2。

问题是,在同一个 Prometheus 数据库中还有其他系统报告,NetApp Harvest 没有在它的指标名称上添加前缀,例如 netapp_ 到每个 netapp 指标。以这种方式找到正确的指标真是太痛苦了。

我想使用 Prometheus_config 的 relable_config 选项作为解决方法。目前我对收获轮询器有以下配置:

 - job_name: harvest
    scrape_interval: 1m
    scrape_timeout: 1m
    metrics_path: /metrics
    relabel_configs:
    - action: replace
      source_labels: [__name__]
      regex: (.*)
      target_label: __name__
      replacement: 'netapp_$1'

    - action: keep
      source_labels:
      - "custom_labels"
      - "custom_labels"
      - "custom_labels"
      - "custom_labels"
      regex: '.+;.+;.+;.+'

    file_sd_configs:
     - refresh_interval: 10s
       files:
       - targets/harvest.yml

但这会导致 Grafana/Prometheus 中根本没有出现收获轮询器。关于如何添加所需前缀的任何想法?

4

1 回答 1

1

此配置存在两个问题,但它们具有相同的原因。此外,在这种情况下,添加前缀可能不是最好的主意。确保您阅读了此答案末尾的注释。

问题是relabel_configs包含应该在抓取之前应用的重新标记配置。例如,您可以更改__address__,以便 Prometheus 将联系其他主机,而不是服务发现提供的主机。当然,__name__此时不可用,因为Prometheus 还没有刮掉任何东西

解决方案是移至__name__. metric_relabel_configs在这一步,指标已收集但尚未摄取,您可以更改它们的__name__. 这是一个super_为所有抓取的指标添加前缀的示例:

metric_relabel_configs:
- source_labels: [__name__]
  target_label: __name__
  replacement: super_$1

问题中的第二次重新标记几乎相同:

    - action: keep
      source_labels:
      - "custom_labels"
      - "custom_labels"
      - "custom_labels"
      - "custom_labels"
      regex: '.+;.+;.+;.+'

指标还没有被抓取,所以还没有自定义标签。这有效地删除了所有目标,因为没有提到的标签。如果您认为需要重新标记(不需要为标签名称添加前缀),则必须将其放在metric_relabel_configs.

为什么为标签名称添加前缀可能不是最好的主意

问题在于,由于标签名称不同,您将无法使用具有重命名指标的相同仪表板/警报。您将不得不为这些指标制作单独的仪表板,或者使用奇怪且无效的查询,例如:

{__name__=~".*my_metric_without_prefix"}

最好简单地添加一个标签,将一组指标与另一组指标区分开来。您可以添加自己的新标签或使用不同的作业来抓取这些指标。在最后一种情况下,您可以通过job标签将一组指标与另一组指标区分开来。

于 2021-10-20T08:20:59.540 回答