13

背景

我已经使用Helm chart for Prometheus在我的 Kubernetes 集群(托管在 Google Container Engineer 上)上安装了 Prometheus 。

问题

我无法弄清楚如何将抓取目标添加到 Prometheus 服务器。prometheus.io 站点描述了我如何将 prometheus.yml 文件(其中包含抓取目标列表)安装到 Prometheus Docker 容器——我已经在本地完成了这个并且它可以工作。但是,我不知道如何为通过 Kubernetes-Helm 安装的 Prometheus 设置指定抓取目标。我是否需要向包含抓取目标的 Prometheus 服务器 pod 添加一个卷,从而更新 Helm 生成的 YAML 文件?

我也不清楚如何在 Kubernetes Pod 中公开指标——我是否需要转发特定端口?

4

2 回答 2

19

您需要为要监控的服务添加注释。

apiVersion: v1
kind: Service
metadata:
  annotations:
    prometheus.io/scrape: 'true'

来自图表中的 prometheus.yml:

  • prometheus.io/scrape:只抓取价值为true
  • prometheus.io/scheme: http 或 https
  • prometheus.io/path:如果指标路径不是,则覆盖/metrics
  • prometheus.io/port:如果指标暴露在不同的端口上

是的,您需要向服务公开带有指标的端口,以便 Prometheus 可以访问它

于 2017-08-12T04:22:22.947 回答
1

首先,你需要创建一个Service Monitor,它是一个自定义的K8s资源。servicemonitor.yaml只需在 manifests 文件夹中创建一个。

因为当我们在 K8s 上部署时,我们无法访问 Prometheus.yaml 文件来提及目标,所以我们创建了 servicemonitor,它反过来将目标添加到 Prometheus.yaml 文件中的 scrap_config 中。您可以从这里了解更多信息。

这是在 Prometheus 中公开 Flask App 指标的示例servicemonitor.yaml文件。

apiVersion: monitoring.coreos.com/v1 
kind: ServiceMonitor 
metadata:
  name: flask-metrics
  namespace: prometheus # namespace where prometheus is running
  labels:
    app: flask-app
    release: prom  # name of the release 
    # ( VERY IMPORTANT: You need to know the correct release name by viewing 
    # the servicemonitor of Prometheus itself: Without the correct name, 
    #  Prometheus cannot identify the metrics of the Flask app as the target.)
spec:
  selector:
    matchLabels:
      # Target app service
      app: flask-app # same as above
      release: prom # same as above
  endpoints:
  - interval: 15s # scrape interval
    path: /metrics # path to scrape
    port: http # named port in target app
  namespaceSelector:
    matchNames:
    - flask # namespace where the app is running

还要将此发布标签添加到服务和部署文件的元数据和规范部分。

如果您遇到 Prometheus 显示目标而不显示端点的情况,请查看以下内容:https ://github.com/prometheus-operator/prometheus-operator/issues/3053

一些有用的链接:

于 2021-11-22T23:20:02.060 回答