本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com
MetalLB是裸金属Kubernetes集群的负载均衡器实现,使用标准路由协议。
MetalLB概述
商标声明:本软件列表由Bitnami打包。所提及的相关商标归各自公司所有,使用这些商标并不意味着任何关联或认可。
helm install my-release oci://registry-1.docker.io/bitnamicharts/metallb
希望在生产环境中使用MetalLB?请尝试VMware Tanzu Application Catalog,即Bitnami目录的商业版。
自2025年8月28日起,Bitnami将升级其公共目录,在新的Bitnami Secure Images计划下提供精选的强化、安全聚焦镜像。作为此过渡的一部分:
这些变更旨在通过推广软件供应链完整性和最新部署的最佳实践,提升所有Bitnami用户的安全态势。更多详情,请访问Bitnami Secure Images公告。
Bitnami Helm Chart经过精心设计、积极维护,是在Kubernetes集群上部署容器的最快、最简单方式,可直接用于生产工作负载。
此Chart使用Helm包管理器在Kubernetes集群上引导MetalLB Controller部署和MetalLB Speaker守护进程集。
要使用发布名称my-release安装Chart:
helm install my-release oci://REGISTRY_NAME/REPOSITORY_NAME/metallb
注意:需将占位符
REGISTRY_NAME和REPOSITORY_NAME替换为Helm Chart仓库和存储库的引用。例如,对于Bitnami,需使用REGISTRY_NAME=registry-1.docker.io和REPOSITORY_NAME=bitnamicharts。
这些命令以默认配置在Kubernetes集群上部署metallb。参数部分列出了安装期间可配置的参数。
提示:使用
helm list列出所有发布。
Bitnami Chart允许为Chart部署内的所有容器设置资源请求和限制,这些配置位于resources值中(参见参数表)。设置请求对于生产工作负载至关重要,应根据具体使用场景调整。
为简化此过程,Chart包含resourcesPreset值,可根据不同预设自动设置resources部分。可在bitnami/common chart中查看这些预设。但在生产工作负载中,不建议使用resourcesPreset,因其可能无法完全适应具体需求。有关容器资源管理的更多信息,请参阅Kubernetes官方文档。
通过将*.metrics.enabled(在controller、speaker和speaker.frr部分下)设置为true,可将此Chart与Prometheus集成。这将在容器和服务中暴露MetalLB原生Prometheus端口,服务还将包含必要的注解以被Prometheus自动抓取。
集成需确保集群中已安装Prometheus或Prometheus Operator。可安装Bitnami Prometheus helm chart或Bitnami Kube Prometheus helm chart以快速获得可用的Prometheus。
通过设置*.metrics.serviceMonitor.enabled=true(在controller、speaker和speaker.frr部分下),Chart可部署ServiceMonitor对象以与Prometheus Operator集成。需确保集群中已安装Prometheus Operator的自定义资源定义(CRD),否则将失败并显示以下错误:
no matches for kind "ServiceMonitor" in version "monitoring.coreos.com/v1"
安装Bitnami Kube Prometheus helm chart以获取必要的CRD和Prometheus Operator。
强烈建议在生产环境中使用不可变标签。这可确保如果相同标签更新为不同镜像时,部署不会自动更改。
如果主容器有新版本、重大变更或存在严重漏洞,Bitnami将发布新Chart以更新其容器。
要配置MetalLB,请参阅配置部分MetalLB配置。
要在Kubernetes上备份和恢复Helm Chart部署,需使用Kubernetes备份/恢复工具Velero备份源部署的持久卷,并将其附加到新部署。有关使用Velero的说明,请参阅本指南。
# address-pools列出MetalLB允许分配的IP地址。可根据需要创建多个地址池。 apiVersion: metallb.io/v1beta1 kind: IPAddressPool metadata: # 地址池名称。服务可使用此名称请求从特定地址池分配。 name: first-pool namespace: metallb-system spec: # MetalLB有权限管理的IP地址范围列表。可在单个池中列出多个范围,它们将共享相同的设置。每个范围可以是CIDR前缀或显式的IP起止范围。 addresses: - 192.168.10.0/24 - 192.168.9.1-192.168.9.5 - fc00:f853:0ccd:e799::/124
| 名称 | 描述 | 值 |
|---|---|---|
global.imageRegistry | 全局Docker镜像仓库 | "" |
global.imagePullSecrets | 全局Docker仓库密钥名称数组 | [] |
global.security.allowInsecureImages | 允许跳过镜像验证 | false |
global.compatibility.openshift.adaptSecurityContext | 调整部署的securityContext部分以使其与OpenShift restricted-v2 SCC兼容:移除runAsUser、runAsGroup和fsGroup,让平台使用其允许的默认ID。可能值:auto(如果检测到运行的集群是OpenShift则应用)、force(始终执行调整)、disabled(不执行调整) | auto |
| 名称 | 描述 | 值 |
|---|---|---|
kubeVersion | 强制目标Kubernetes版本(未设置则使用Helm能力) | "" |
nameOverride | 部分覆盖metallb.fullname的字符串(将保留发布名称) | "" |
fullnameOverride | 完全覆盖metallb.fullname模板的字符串 | "" |
commonLabels | 为所有部署的资源添加标签 | {} |
commonAnnotations | 为所有部署的资源添加注解 | {} |
extraDeploy | 随发布一起部署的额外对象数组 | [] |
diagnosticMode.enabled | 启用诊断模式(所有探针将被禁用,命令将被覆盖) | false |
diagnosticMode.command | 覆盖部署/有状态集中所有容器的命令 | ["sleep"] |
diagnosticMode.args | 覆盖部署/有状态集中所有容器的参数 | ["infinity"] |
installCRDs | 安装metallb CRD的标志 | true |
| 名称 | 描述 | 值 |
|---|---|---|
rbac.create | 指定是否安装和使用RBAC规则 | true |
psp.create | 是否创建PodSecurityPolicy。警告:PodSecurityPolicy在Kubernetes v1.21及更高版本中已弃用,在v1.25及更高版本中不可用 | false |
networkPolicy.enabled | 启用NetworkPolicy资源创建 | true |
networkPolicy.allowExternal | 应用的策略模型 | true |
networkPolicy.allowExternalEgress | 允许Pod访问任何端口范围和所有目标 | true |
networkPolicy.kubeAPIServerPorts | kube-apiserver的可能端点列表(限制到集群设置以提高安全性) | [] |
networkPolicy.extraIngress | 向NetworkPolicy添加额外的入站规则 | [] |
networkPolicy.extraEgress | 向NetworkPolicy添加额外的出站规则 | [] |
networkPolicy.ingressNSMatchLabels | 用于匹配以允许来自其他命名空间流量的标签 | {} |
networkPolicy.ingressNSPodMatchLabels | 用于匹配以允许来自其他命名空间Pod流量的Pod标签 | {} |
prometheusRule.enabled | 创建Prometheus Operator alertmanager告警 | false |
| 名称 | 描述 | 值 |
|---|---|---|
controller.image.registry | MetalLB Controller镜像仓库 | REGISTRY_NAME |
controller.image.repository | MetalLB Controller镜像存储库 | REPOSITORY_NAME/metallb-controller |
controller.image.digest | MetalLB Controller镜像摘要,格式为sha256:aa....注意:如果设置此参数,将覆盖标签 | "" |
controller.image.pullPolicy | MetalLB Controller镜像拉取策略 | IfNotPresent |
controller.image.pullSecrets | 指定docker-registry密钥名称数组 | [] |
controller.updateStrategy.type | MetalLB controller部署策略类型 | RollingUpdate |
controller.automountServiceAccountToken | 在Pod中挂载服务账户令牌 | true |
controller.hostAliases | 部署Pod的主机别名 | [] |
controller.rbac.create | 指定是否安装和使用RBAC规则 | true |
controller.psp.create | 是否创建PodSecurityPolicy。警告:PodSecurityPolicy在Kubernetes v1.21及更高版本中已弃用,在v1.25及更高版本中不可用 | true |
controller.priorityClassName | MetalLB controller Pod的priorityClassName | "" |
controller.runtimeClassName | MetalLB controller Pod使用的运行时类名称 | "" |
controller.schedulerName | k8s调度器名称(非默认) | "" |
controller.terminationGracePeriodSeconds | MetalLB controller Pod优雅终止的时间(秒) | 0 |
controller.topologySpreadConstraints | Pod分配的拓扑扩展约束 | [] |
controller.resourcesPreset | 根据通用预设设置容器资源(允许值:none、nano、micro、small、medium、large、xlarge、2xlarge)。如果设置了controller.resources,则忽略此参数(controller.resources推荐用于生产环境) | nano |
controller.resources | 设置容器对CPU或内存等不同资源的请求和限制(生产工作负载必需) | {} |
controller.nodeSelector | controller Pod分配的节点标签 | {} |
controller.tolerations | controller Pod分配的容忍度 | [] |
controller.affinity | controller Pod分配的亲和性 | {} |
controller.podAnnotations | Controller Pod注解 | {} |
controller.podLabels | Controller Pod标签 | {} |
controller.podAffinityPreset | Controller Pod亲和性预设。允许值:soft、hard | "" |
controller.podAntiAffinityPreset | Controller Pod反亲和性预设。允许值:soft、hard | soft |
controller.nodeAffinityPreset.type | Controller Pod节点亲和性预设。允许值:soft、hard | "" |
controller.nodeAffinityPreset.key | Controller Pod节点亲和性匹配的标签键 | "" |
controller.nodeAffinityPreset.values | Controller Pod节点亲和性匹配的标签值 | [] |
注意:此Chart的README超出DockerHub 25000字符限制,已被截断。完整README可在[***]

免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429