13

Prometheus Operator https://github.com/coreos/prometheus-operator/项目的 github repo说

Prometheus Operator 使 Prometheus 配置 Kubernetes 原生,并管理和操作 Prometheus 和 Alertmanager 集群。这是关于完整的端到端监控的一部分。

kube-prometheus 将 Prometheus Operator 与清单集合相结合,以帮助开始监控 Kubernetes 本身以及在其上运行的应用程序。

有人可以详细说明吗?

4

4 回答 4

10

我一直有同样的问题/反复碰到这两个问题,但是阅读上述答案并没有为我澄清/我需要一个简短的解释。我发现这个 github 问题让我很清楚。 https://github.com/coreos/prometheus-operator/issues/2619

引用 GitHub 的 nicgirault:

最后我意识到 prometheus-operator chart 正在打包 kube-prometheus 堆栈,但我花了大约 10 个小时才意识到这一点。

**这是我的总结解释:
“kube-prometheus”和“Prometheus Operator Helm Chart”都做同样的事情:

  1. 基本上是 Ingress/Ingress Controller 概念,适用于 Metrics/Prometheus Operator。
  2. 两者都是在 Kubernetes 上轻松配置、安装和管理大型分布式应用程序(Kubernetes Prometheus Stack)的一种方式:**

    您问的整个 Kube Prometheus 堆栈是什么?
    Prometheus、Grafana、AlertManager、CRD(自定义资源定义)、Prometheus Operator(软件机器人应用程序)、IaC 警报规则、IaC Grafana Dashboards、IaC ServiceMonitor CRD(自动生成 Prometheus Metric Collection Configuration 并自动将其热导入 Prometheus Server)
    (另外,当我说轻松配置时,我的意思是 1,000-10,000++ 行易于人类理解的配置,生成和自动管理 10,000-100,000 行机器配置 + 具有合理默认值的东西 + 监控配置自助服务,分布式配置分片一个操作员/控制器结合配置+从漂亮的人类可读配置生成详细的样板机器可读配置。

如果他们实现相同的最终目标,您可能会问他们之间有什么区别?
https://github.com/coreos/kube-prometheus
https://github.com/helm/charts/tree/master/stable/prometheus-operator
基本上CoreOS的kube-prometheus使用Ksonnet部署Prometheus Stack。
Prometheus Operator Helm Chart 包装了 kube-prometheus / 实现了相同的最终结果,但使用了 Helm。

那么使用哪一个呢?
没关系 + 他们达到相同的最终结果 + 从 1 开始并切换到另一个应该不会很困难。

Helm 往往更快地学习/发展基本的掌握。

Ksonnet 更难学习/发展基本掌握,但是:

  • 它更幂等(对于 CICD 自动化更好)(但它只是 99% 幂等与 99.99% 幂等的区别。)
  • 具有内置模板,这意味着如果您有多个集群,您需要管理/您希望始终保持彼此一致。然后,您可以利用具有大量代码重用的 DRY 代码库,利用 ksonnet 的模板来管理 Kube Prometheus Stack 的多个实例(用于多个环境)。(如果您只有几个 env 并且 Prometheus 不需要经常更改,那么手动保持 4 个 helm 值文件同步并非完全不合理。我还看到 Jinja2 模板用于模板化 helm 值文件,但是如果您'会打扰你不妨考虑ksonnet。)
于 2019-09-25T23:53:17.207 回答
7

Kubernetes operator是 Kubernetes 特定的应用程序(pod),可以自动配置、管理和优化其他 Kubernetes 部署。它们被实现为自定义控制器。

根据coreOS官方网站:

算子是CoreOS引入的一类软件,可以操作其他软件,将人类收集到的操作知识放到软件中。

prometheus operator 提供了一种在 kubernetes 集群上部署配置和监控 prometheus 实例的简单方法。为此,prometheus operator 在 kubernetes 中引入了三种类型的自定义资源定义(CRD)。

  1. 普罗米修斯
  2. 警报管理器
  3. 服务监控

现在,借助上述 CRD,您可以通过提供直接创建一个 prometheus 实例,kind: Prometheus并且该 prometheus 实例已准备好服务,同样您可以为AlertManager. 如果没有这个,你将不得不为 prometheus 设置部署,包括它的镜像、配置和更多的东西。

Prometheus Operator 的作用是让在 Kubernetes 上运行 Prometheus 尽可能简单,同时保留 Kubernetes 原生配置选项。

现在,kube-prometheus 实现了 prometheus 操作符,并为您提供最少的 yaml 文件来创建您的基本设置prometheusalertmanagergrafana通过运行单个命令。

git clone https://github.com/coreos/prometheus-operator.git
kubectl apply -f prometheus-operator/contrib/kube-prometheus/manifests/

通过在 kube-prometheus 目录中运行上述命令,您将获得一个monitoring命名空间,该命名空间将具有 alertmanager 的实例,prometheusgrafana用于 UI。这对于大多数基本实现来说已经足够了,如果您需要根据您的应用程序的更多细节,您可以添加更多您需要的导出器 yaml。

kube-prometheus 更多的是对 prometheus-operator 项目的贡献,它很好地实现了 prometheus 操作符功能,并为您的 kubernetes 集群提供了完整的监控设置。您可以从 kube-prometheus 开始,并根据您的应用程序从那里扩展监控设置的功能。

您可以在此处了解有关 prometheus-operator 的更多信息

于 2019-01-29T14:44:54.173 回答
1

截至今天,2020 年 9 月 28 日,这是在 Kubernetes 集群中安装 Prometheus 的方式 https://github.com/prometheus-community/helm-charts/tree/main/charts/kube-prometheus-stack#kube -普罗米修斯堆栈

于 2020-09-28T17:29:19.257 回答
0

根据官方文档,kube-prometheus-stack 是对 prometheus-operator 的重命名。据我了解,kube-prometheus-stack 还预装了 grafana 仪表板和 prometheus 规则。

注意:该图表原名为 prometheus-operator 图表,现更名以更清楚地反映它安装了 kube-prometheus 项目堆栈,其中 Prometheus Operator 只是其中一个组件。

取自https://github.com/prometheus-community/helm-charts/tree/main/charts/kube-prometheus-stack

于 2021-11-23T15:33:02.813 回答