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资源。

相关推荐
低调的JVM1 小时前
K8s环境下Java-Agent自动注入方案详解
kubernetes·软件监控·k8s注入
-L711 小时前
【Kubernetes】常见面试题汇总(十九)
云原生·容器·kubernetes
Gss77714 小时前
Docker 公有仓库使用、Docker 私有仓库(Registry)使用总结
docker·容器
暴富奥利奥14 小时前
完成docker方式的ros环境配置
linux·学习·docker·容器
红尘客栈215 小时前
K8s-kubeadmin 1.28安装
java·网络·kubernetes
红尘客栈215 小时前
K8S基本命令操作
linux·容器·kubernetes
我好饿115 小时前
部署k8s集群+containerd+dashboard
云原生·容器·kubernetes
hello_25015 小时前
动手模拟k8s网络-vxlan模式
网络·容器·kubernetes
济南java开发,求内推16 小时前
两台服务器搭建三个节点
云原生·eureka
阿里云云原生16 小时前
2025 云栖精选资料:《从云原生到 AI 原生核心技术与最佳实践》PPT 免费下载
云原生