k8s service 配置AWS nlb load_balancing.cross_zone.enabled

在Kubernetes中配置NLB(Network Load Balancer)的跨区域负载均衡(cross-zone load balancing),需要使用服务注解(service annotations)来实现。根据AWS官方文档,以下是配置NLB跨区域负载均衡的步骤:

1 使用service.beta.kubernetes.io/aws-load-balancer-attributes注解

需要将之前用于配置NLB属性的各种注解合并到service.beta.kubernetes.io/aws-load-balancer-attributes注解中。这个注解接受一个逗号分隔的键值对列表,用于配置NLB的各种属性。例如,要指定代理协议、访问日志和跨区域负载均衡,可以使用以下格式:

复制代码
service.beta.kubernetes.io/aws-load-balancer-attributes: |
  proxy_protocol.v2.enabled=true
  access_logs.s3.enabled=true
  access_logs.s3.bucket=my-bucket
  access_logs.s3.prefix=my-prefix
  load_balancing.cross_zone.enabled=true

在这个合并的格式中,你可以更一致、灵活地配置负载均衡器属性,同时减少所需的单独注解数量。

2 配置Kubernetes服务

在Kubernetes服务配置中,需要添加上述注解来启用跨区域负载均衡。以下是一个包含跨区域负载均衡配置的Kubernetes服务示例:

复制代码
apiVersion: v1
kind: Service
metadata:
  name: my-service
  annotations:
    service.beta.kubernetes.io/aws-load-balancer-attributes: |
      proxy_protocol.v2.enabled=true
      access_logs.s3.enabled=true
      access_logs.s3.bucket=my-bucket
      access_logs.s3.prefix=my-prefix
      load_balancing.cross_zone.enabled=true
spec:
  selector:
    app: my-app
  ports:
    - port: 80
      targetPort: 8080
  type: LoadBalancer

在这个配置中,load_balancing.cross_zone.enabled=true就是启用NLB跨区域负载均衡的关键配置。

注意:

这些配置需要AWS Load Balancer Controller来管理NLB资源。确保集群已经部署了AWS Load Balancer Controller,并且正常运行。这样,当创建或更新服务时,AWS Load Balancer Controller会根据注解配置来创建或更新NLB资源。

相关推荐
lpruoyu15 分钟前
【云原生】kustomize_常见的部署方式
云原生
春日见28 分钟前
UniAD的逻辑,与传统自动驾驶的差异
人工智能·windows·git·机器学习·docker·容器·自动驾驶
乐观的Terry31 分钟前
Docker 部署 RocketMQ 5.1.0 踩坑实录:从超时到 Console 连不上的完整解决之路
docker·容器·rocketmq
切糕师学AI42 分钟前
K8s中的控制器模式(Controller Pattern)
容器·kubernetes
sanyii31313143 分钟前
k8s工作负载-Deployment的参数与灰度发布
云原生·容器·kubernetes
fajianchen1 小时前
如何设计微服务统一认证中心
微服务·云原生·架构·iam
大鹏说大话1 小时前
云原生深水区:2026 年 Serverless 函数计算落地实战与成本极致优化
云原生·serverless
道清茗1 小时前
【Kubernetes知识点问答题】常规维护管理操作 / ETCD 备份与恢复
docker·kubernetes·etcd
lpruoyu1 小时前
【云原生】可观测性系统—Istio
云原生·istio
lpruoyu1 小时前
【云原生】Harbor
云原生·harbor