ALB 已被废弃。请改用 ingress-nginx-operator 或 envoy-gateway。
ALB 是表示负载均衡器的自定义资源。alb-operator 默认嵌入所有集群中,监听 ALB 资源的创建/更新/删除操作,并据此创建相应的 Deployment 和 Service。
对于每个 ALB,会有一个对应的 Deployment 监听所有附加到该 ALB 的 Frontends 和 Rules,并根据这些配置将请求路由到后端。
负载均衡器 的高可用性需要 VIP。请参考 配置 VIP。
ALB 配置包含三部分。
资源相关字段描述 alb 的部署配置。
| 字段 | 类型 | 描述 |
|---|---|---|
.spec.config.nodeSelector | map[string]string | alb 的节点选择器 |
.spec.config.replicas | int,可选,默认 3 | alb 的副本数 |
.spec.config.resources.limits | k8s 容器资源限制,可选 | alb 中 nginx 容器的资源限制 |
.spec.config.resources.requests | k8s 容器资源请求,可选 | alb 中 nginx 容器的资源请求 |
.spec.config.resources.alb.limits | k8s 容器资源限制,可选 | alb 中 alb 容器的资源限制 |
.spec.config.resources.alb.requests | k8s 容器资源请求,可选 | alb 中 alb 容器的资源请求 |
.spec.config.antiAffinityKey | string,可选,默认 local | k8s 反亲和性键 |
网络字段描述如何访问 ALB。例如,在 host 模式下,alb 使用 hostnetwork,可以通过节点 IP 访问 ALB。
| 字段 | 类型 | 描述 |
|---|---|---|
.spec.config.networkMode | string: host 或 container,可选,默认 host | 在 container 模式下,operator 会创建 LoadBalancer 类型的 Service,并使用其地址作为 ALB 地址。 |
.spec.address | string,必填 | 可以手动指定 alb 的地址 |
.spec.config.vip.enableLbSvc | bool,可选 | 在 container 模式下自动为 true。 |
.spec.config.vip.lbSvcAnnotations | map[string]string,可选 | LoadBalancer Service 的额外注解 |
| 字段 | 类型 |
|---|---|
.spec.config.projects | []string,必填 |
.spec.config.portProjects | string,可选 |
.spec.config.enablePortProject | bool,可选 |
将 ALB 添加到项目意味着:
如果启用端口项目并为项目分配端口范围,则意味着:
alb cr 中有一些全局配置可以调优。
Web UI 中暴露了一些常用配置。创建负载均衡器的步骤如下:
Web UI 中的每个输入项对应 CR 的一个字段:
| 参数 | 描述 |
|---|---|
| Assigned Address | .spec.address |
| Allocated By | Instance 表示项目模式,可选择下方项目;port 表示端口项目模式,创建 alb 后可分配端口范围 |
更新负载均衡器会导致 3 到 5 分钟的服务中断,请选择合适时间进行操作!
进入 Administrator。
左侧导航栏点击 网络管理 > 负载均衡器。
点击 ⋮ > 更新。
根据需要更新网络和资源配置。
点击 更新。
删除负载均衡器后,关联的端口和规则也会被删除且无法恢复。
进入 Administrator。
左侧导航栏点击 网络管理 > 负载均衡器。
点击 ⋮ > 删除,并确认。
Frontend 是定义 ALB 监听端口和协议的自定义资源。 支持的协议:L7(http|https|grpc|grpcs)和 L4(tcp|udp)。
如果需要添加 HTTPS 监听端口,还应联系管理员为当前项目分配 TLS 证书以实现加密。
先创建 ALB。
alb 标签:必填,指明该 Frontend 所属的 ALB 实例。
frontend 名称:格式为 $alb_name-$port。
port:监听的端口。
protocol:该端口使用的协议。
certificate_name:用于 grpcs 和 https 协议的默认证书,格式为 $secret_ns/$secret_name。
backendProtocol:后端服务使用的协议。
默认 serviceGroup:
serviceGroup。
进入 Container Platform。
左侧导航栏点击 网络 > 负载均衡。
点击负载均衡器名称进入详情页。
点击 添加端口。
Web UI 中的每个输入项对应 CR 的一个字段:
| 参数 | 描述 |
|---|---|
| Session Affinity | .spec.serviceGroup.session_affinity_policy |
对于 HTTP、gRPC 和 HTTPS 端口的流量,除了默认的内部路由组外,还可以设置更多多样化的后端服务匹配 规则。负载均衡器会先根据设置的规则匹配对应的后端服务;若规则匹配失败,则匹配上述内部路由组对应的后端服务。
可以点击列表页右侧的 ⋮ 图标,或详情页右上角的 操作,根据需要更新默认路由或删除监听端口。
如果负载均衡器的资源分配方式为 端口,只有管理员可以在 Administrator 视图中删除相关监听端口。
Rule 是定义 ALB 如何匹配和处理请求的自定义资源。
ALB 处理的 ingress 可以被 自动转换为规则。
下面是一个示例规则,帮助快速了解规则的使用。
规则必须通过标签附加到 frontend 和 alb。
Frontend。DSLX 是用于描述匹配条件的领域专用语言。 例如,下面的规则匹配满足 全部 以下条件的请求:
优先级是 0 到 10 的整数,数值越小优先级越高。Ingress 中配置规则优先级可使用如下注解格式:
规则中直接在 .spec.priority 使用整数设置优先级。
请求匹配规则后,可以对请求应用以下动作:
| 功能 | 描述 | 链接 |
|---|---|---|
| Timeout | 配置请求超时设置 | timeout |
| Redirect | 将请求重定向到指定 URL | redirect |
| CORS | 启用跨域资源共享(CORS) | cors |
| Header Modification | 允许修改请求或响应头 | header modification |
| URL Rewrite | 转发前重写请求 URL | url-rewrite |
| WAF | 集成 Web 应用防火墙(WAF) | waf |
| OTEL | 启用 OpenTelemetry(OTEL)进行分布式追踪 | otel |
| Keepalive | 启用或禁用应用的 keepalive 功能 | keepalive |
默认后端协议为 HTTP。若需使用 TLS 重新加密,可配置为 HTTPS。
规则中可配置一个或多个服务。
默认情况下,ALB 使用轮询(RR)算法在后端服务间分发请求。也可为单个服务分配权重,或选择其他负载均衡算法。
详情请参考 负载均衡算法。

Web UI 中的每个输入项对应 CR 的一个字段。
若 frontend 协议(ft)为 HTTPS 或 GRPCS,规则也可配置为使用 HTTPS。
证书可在规则或 ingress 中指定,用于匹配该端口的证书。
支持终止(termination),若后端协议为 HTTPS 可实现重新加密。但不能为与后端服务通信指定证书。
证书可通过注解跨命名空间引用。
.spec.certificate_name 格式为 $secret_namespace/$secret_name
Edge 模式下,客户端与 ALB 使用 HTTPS 通信,ALB 与后端服务使用 HTTP 协议。 实现方式:
.spec.certificate_name 指定证书重新加密模式下,客户端与 ALB 使用 HTTPS 通信,ALB 与后端服务使用 HTTPS 协议。 实现方式:
.spec.certificate_name 指定证书每个 ALB 创建一个同名的 IngressClass,处理同项目内的 ingress。
当 ingress 命名空间带有标签如 cpaas.io/project: demo,表示该 ingress 属于 demo 项目。
ALB 中 .spec.config.projects 配置包含项目名 demo 的,会自动将这些 ingress 转换为规则。
ALB 监听 ingress 并自动创建 Frontend 或 Rule。source 字段定义如下:
spec.source.type 目前仅支持 ingress。spec.source.name 是 ingress 名称。spec.source.namespace 是 ingress 命名空间。对于未配置证书的 ingress,ALB 提供使用默认证书的策略。
可在 ALB 自定义资源中配置:
.spec.config.defaultSSLStrategy:定义未配置证书 ingress 的 SSL 策略.spec.config.defaultSSLCert:设置默认证书,格式为 $secret_ns/$secret_name可用 SSL 策略:
结合日志和监控数据,可以快速定位和解决负载均衡器问题。
进入 Administrator。
左侧导航栏点击 网络管理 > 负载均衡器。
点击 负载均衡器名称。
在 日志 标签页,从容器视角查看负载均衡器运行日志。
负载均衡器所在集群必须部署监控服务。
进入 Administrator。
左侧导航栏点击 网络管理 > 负载均衡器。
点击 负载均衡器名称。
在 监控 标签页,从节点视角查看负载均衡器的指标趋势信息。
更多监控指标详情请参考 ALB 监控。