kubernetes prometheus dynamic metrics_path

zbq4xfa0  于 2024-01-06  发布在  Kubernetes
关注(0)|答案(4)|浏览(152)

Prometheus允许我从一个.json文件中动态加载目标文件file_sd_config,如下所示:

  1. #prometheus.yaml
  2. - job_name: 'kube-metrics'
  3. file_sd_configs:
  4. - files:
  5. - 'targets.json'

个字符
但是,我的目标在metrics_path中不同,而不是主机(我想为<kube-api-server>/api/v1/nodes/<node-name>/proxy/metrics/cadvisor上的每个kubernetes节点收集指标)但是我只能在作业级别而不是每个目标设置metrics_path。这甚至可以用prometheus实现吗?或者我必须编写自己的代码来抓取所有这些指标并将其导出到单个目标。此外,我找不到所有支持的列表自动发现机制,我在文档中错过了什么吗?

u3r8eeie

u3r8eeie1#

您可以在Prometheus config中使用relabel_config来更改__metrics_path__标签配置。
原则是以host:port/path/of/metrics的形式在目标中提供指标路径(注意:删除http://,它在scrape_configscheme参数中)

  1. [
  2. {
  3. "targets": [
  4. "node1:8080/first-metrics",
  5. "node2:8080/second-metrics"
  6. ]
  7. }
  8. ]

字符串
然后将相关的元标签替换为

  1. - job_name: 'kube-metrics'
  2. file_sd_configs:
  3. - files:
  4. - 'targets.json'
  5. relabel_configs:
  6. - source_labels: [__address__]
  7. regex: '[^/]+(/.*)' # capture '/...' part
  8. target_label: __metrics_path__ # change metrics path
  9. - source_labels: [__address__]
  10. regex: '([^/]+)/.*' # capture host:port
  11. target_label: __address__ # change target


您可以在配置时对任何已知的标签重复使用此方法,以修改刮取的配置。
在Prometheus上,使用服务发现页面检查您的配置是否已正确修改。
服务发现的官方列表在配置文档中:在索引中查找*_sd_config

展开查看全部
xe55xuns

xe55xuns2#

有一种稍微优雅的方法可以做到这一点,它不涉及操作地址。您可以为目标创建一个标签,该标签可以作为您的“重新标记”操作的源,类似于以下内容:

  1. - labels:
  2. __meta_discovery_path: '/first-metrics'
  3. targets:
  4. - 'node1:8080'
  5. - labels:
  6. __meta_discovery_path: '/second-metrics'
  7. targets:
  8. - 'node2:8080'

字符串
然后,您的重新标记将简单地:

  1. relabel_configs:
  2. - source_labels: [__meta_discovery_path]
  3. target_label: __metrics_path__ # change metrics path


由于正在使用的标签以“__"开头,因此它将从正在提取的指标中剥离,使其变得美观和干净。

展开查看全部
8iwquhpp

8iwquhpp3#

我想要的东西像下面的端点和实现与此配置

  1. 192.168.1.1:80/metrics/my-path1
  2. 192.168.1.2:80/metrics/my-path1

字符串
这将用_new_path值替换$1

  1. - job_name: prometheus_dynamic_metrics_path
  2. honor_labels: true
  3. honor_timestamps: true
  4. scrape_interval: 15s
  5. scrape_timeout: 10s
  6. metrics_path: /metrics
  7. scheme: http
  8. follow_redirects: true
  9. relabel_configs:
  10. - source_labels: [_new_path]
  11. separator: ;
  12. regex: (.*)
  13. target_label: __metrics_path__
  14. replacement: /metrics/$1
  15. action: replace
  16. static_configs:
  17. - targets:
  18. - 192.168.1.1:80
  19. labels:
  20. _new_path: my-path1
  21. - targets:
  22. - 192.168.1.2:80
  23. labels:
  24. _new_path: my-path2

展开查看全部
5jvtdoz2

5jvtdoz24#

您可以使用特殊标签在目标级别设置指标路径和方案。您甚至可以更改刮取间隔,超时和作业名称:

  1. [
  2. {
  3. "targets": [ "yourhost:1234" ],
  4. "labels": {
  5. "job": "override job's name",
  6. "__metrics_path__": "/my/custom/path",
  7. "__scheme__": "https",
  8. "__scrape_interval__": "30s",
  9. "__scrape_timeout__": "30s"
  10. }
  11. }
  12. ]

字符串

相关问题