Prometheus 是一款开源的监控和告警系统,能够通过配置的目标定期采集指标,帮助系统管理员监控基础设施。Bitnami 提供的 Prometheus Helm Chart 经过精心设计和维护,可快速、简便地在 Kubernetes 集群中部署 Prometheus,适用于开发和生产环境的容器化应用监控需求。
Prometheus 官方概述
商标说明:本软件列表由 Bitnami 打包。所提及的商标分别归各自公司所有,使用这些商标并不意味着任何关联或认可。
consolehelm install my-release oci://registry-1.docker.io/bitnamicharts/prometheus
注意:生产环境建议使用 VMware Tanzu Application Catalog(Bitnami 商业版目录)。
使用发布名称 my-release 安装 Chart:
consolehelm install my-release oci://REGISTRY_NAME/REPOSITORY_NAME/prometheus
注意:需替换占位符
REGISTRY_NAME和REPOSITORY_NAME。例如,Bitnami 官方仓库需使用REGISTRY_NAME=registry-1.docker.io和REPOSITORY_NAME=bitnamicharts。
默认配置将在 Kubernetes 集群中部署 Prometheus。可通过 参数 部分配置自定义选项。
提示:使用
helm list查看所有发布。
资源请求与限制
Bitnami Charts 允许为部署中的所有容器设置资源请求和限制,通过 resources 参数配置。生产环境必须设置资源请求,并根据实际需求调整。
可通过 resourcesPreset 参数应用预设资源配置(详见 https://github.com/bitnami/charts/blob/main/bitnami/common/templates/_resources.tpl#L15%EF%BC%89%EF%BC%8C%E4%BD%86%E7%94%9F%E4%BA%A7%E7%8E%AF%E5%A2%83%E4%B8%8D%E5%BB%BA%E8%AE%AE%E4%BE%9D%E8%B5%96%E9%A2%84%E8%AE%BE%EF%BC%8C%E9%9C%80%E6%A0%B9%E6%8D%AE%E5%85%B7%E4%BD%93%E8%B4%9F%E8%BD%BD%E8%87%AA%E5%AE%9A%E4%B9%89%E3%80%82%E6%9B%B4%E5%A4%9A%E4%BF%A1%E6%81%AF%E5%8F%82%E8%A7%81 Kubernetes 容器资源管理文档。
滚动标签与不可变标签
生产环境强烈建议使用不可变标签,避免因标签更新导致部署自动变更。Bitnami 会在主容器更新、重大变更或存在严重漏洞时发布新 Chart 更新容器镜像。
部署额外资源
可通过 extraDeploy 参数部署额外 Kubernetes 对象(如 ConfigMap、Deployment 等),需提供完整对象规格。
备份与恢复
使用 Velero(Kubernetes 备份/恢复工具)备份源部署的持久卷,并将其附加到新部署。详见 Velero 使用指南。
Pod 亲和性配置
可通过 XXX.affinity 参数设置自定义亲和性,或使用 https://github.com/bitnami/charts/tree/main/bitnami/common#affinities Chart 提供的预设配置(XXX.podAffinityPreset、XXX.podAntiAffinityPreset、XXX.nodeAffinityPreset)。
与 Thanos 集成
使用 Prometheus Chart 与 https://github.com/bitnami/charts/tree/main/bitnami/thanos 集成(以 MinIO 作为对象存储,部署在 monitoring 命名空间):
values.yaml:yamlobjstoreConfig: |- type: s3 config: bucket: thanos endpoint: {{ include "thanos.minio.fullname" . }}.{{ .Release.Namespace }}.svc.cluster.local:9000 access_key: minio secret_key: minio123 insecure: true query: dnsDiscovery: sidecarsService: prometheus-thanos sidecarsNamespace: monitoring bucketweb: enabled: true compactor: enabled: true storegateway: enabled: true ruler: enabled: true alertmanagers: - http://prometheus-alertmanager.monitoring.svc.cluster.local:9093 config: |- groups: - name: "metamonitoring" rules: - alert: "PrometheusDown" expr: absent(up{prometheus="monitoring/prometheus"}) metrics: enabled: true serviceMonitor: enabled: true minio: enabled: true auth: rootPassword: minio123 rootUser: minio monitoringBuckets: thanos accessKey: password: minio secretKey: password: minio123
consolekubectl create namespace monitoring helm install prometheus \ --set prometheus.thanos.create=true \ --namespace monitoring \ oci://registry-1.docker.io/bitnamicharts/prometheus helm install thanos \ --values values.yaml \ --namespace monitoring \ oci://registry-1.docker.io/bitnamicharts/thanos
与 Grafana Mimir 集成
通过 remoteWrite 配置将 Prometheus 与 Grafana Mimir 集成:
values.yaml:yamlserver: remoteWrite: - url: http://grafana-mimir-gateway.svc.cluster.local/api/v1/push headers: X-Scope-OrgID: demo
consolekubectl create namespace monitoring helm install prometheus \ --values values.yaml \ --namespace monitoring \ oci://registry-1.docker.io/bitnamicharts/prometheus helm install grafana-mimir \ oci://registry-1.docker.io/bitnamicharts/grafana-mimir
与 Grafana 集成
配置 Grafana 数据源连接 Prometheus:
values.yaml:yamldatasources: secretDefinition: apiVersion: 1 datasources: - name: Prometheus type: prometheus access: proxy orgId: 1 url: http://prometheus.monitoring.svc.cluster.local version: 1 editable: true isDefault: true - name: Alertmanager uid: alertmanager type: alertmanager access: proxy orgId: 1 url: http://prometheus-alertmanager.monitoring.svc.cluster.local:9093 version: 1 editable: true
consolekubectl create namespace monitoring helm install prometheus \ --namespace monitoring \ oci://registry-1.docker.io/bitnamicharts/prometheus helm install grafana \ --values values.yaml \ --namespace monitoring \ oci://registry-1.docker.io/bitnamicharts/grafana
添加自定义监控目标
通过 server.extraScrapeConfigs 参数添加自定义监控目标,格式遵循 Prometheus scrape_configs。示例:监控 default 命名空间中的 WordPress:
yamlserver: extraScrapeConfigs: - job_name: wordpress kubernetes_sd_configs: - role: endpoints namespaces: names: - default metrics_path: /metrics relabel_configs: - source_labels: [job] target_label: __tmp_wordpress_job_name - action: keep source_labels: [__meta_kubernetes_service_label_app_kubernetes_io_instance, __meta_kubernetes_service_labelpresent_app_kubernetes_io_instance] regex: (wordpress);true - action: keep source_labels: [__meta_kubernetes_service_label_app_kubernetes_io_name, __meta_kubernetes_service_labelpresent_app_kubernetes_io_name] regex: (wordpress);true - action: keep source_labels: [__meta_kubernetes_endpoint_port_name] regex: metrics # 更多 relabel 配置...
| 参数名 | 描述 | 默认值 |
|---|---|---|
global.imageRegistry | 全局 Docker 镜像仓库 | "" |
global.imagePullSecrets | 全局 Docker 镜像拉取密钥数组 | [] |
global.defaultStorageClass | 持久卷全局默认 StorageClass | "" |
global.storageClass | 已弃用:使用 global.defaultStorageClass 替代 | "" |
global.security.allowInsecureImages | 是否允许跳过镜像验证 | false |
global.compatibility.openshift.adaptSecurityContext | 适配 OpenShift restricted-v2 SCC 的安全上下文(auto/force/disabled) | auto |
| 参数名 | 描述 | 默认值 |
|---|---|---|
kubeVersion | 覆盖 Kubernetes 版本 | "" |
nameOverride | 部分覆盖资源名称前缀 | "" |
fullnameOverride | 完全覆盖资源全名 | "" |
namespaceOverride | 覆盖命名空间 | "" |
commonLabels | 添加到所有资源的标签 | {} |
commonAnnotations | 添加到所有资源的注解 | {} |
clusterDomain | Kubernetes 集群域名 | cluster.local |
extraDeploy | 额外部署的 Kubernetes 对象数组 | [] |
diagnosticMode.enabled | 启用诊断模式(禁用探针并覆盖命令) | false |
diagnosticMode.command | 诊断模式下覆盖所有容器的命令 | ["sleep"] |
diagnosticMode.args | 诊断模式下覆盖所有容器的参数 | ["infinity"] |
ingress.apiVersion | 强制 Ingress API 版本(自动检测如果未设置) | "" |
| 参数名 | 描述 | 默认值 |
|---|---|---|
alertmanager.enabled | 是否启用 Alertmanager | true |
alertmanager.image.registry | Alertmanager 镜像仓库 | REGISTRY_NAME |
alertmanager.image.repository | Alertmanager 镜像名称 | REPOSITORY_NAME/alertmanager |
alertmanager.image.digest | 镜像摘要(覆盖标签,建议使用不可变标签) | "" |
alertmanager.image.pullPolicy | 镜像拉取策略 | IfNotPresent |
alertmanager.image.pullSecrets | 镜像拉取密钥 | [] |
alertmanager.configuration | Alertmanager 配置(模板化内容) | "" |
alertmanager.replicaCount | 副本数 | 1 |
alertmanager.containerPorts.http | HTTP 端口 | 9093 |
alertmanager.containerPorts.cluster | 集群 HA 端口 | 9094 |
alertmanager.livenessProbe.enabled | 是否启用存活探针 | true |
alertmanager.livenessProbe.initialDelaySeconds | 存活探针初始延迟(秒) | 5 |
alertmanager.livenessProbe.periodSeconds | 存活探针周期(秒) | 20 |
alertmanager.livenessProbe.timeoutSeconds | 存活探针超时(秒) | 5 |
注意:完整参数列表请参见 https://github.com/bitnami/charts/blob/main/bitnami/prometheus/README.md%EF%BC%88%E5%8E%9F README 因长度限制被截断)。
自 2025 年 8 月 28 日起,Bitnami 将升级其公共目录,通过 Bitnami Secure Images 计划 提供精选的硬化、安全聚焦镜像。过渡要点:
更多详情参见 https://github.com/bitnami/containers/issues/83267%E3%80%82
以下是 bitnamicharts/prometheus 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 版本下载页面。

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务