10. Kubernetes 的负载均衡器

该项目包括用于基于 Kubernetes Endpoints 的负载均衡的 Spring Cloud Load Balancer,并提供基于 Kubernetes Service 的负载均衡器的实现。 要将其包含在您的项目中,请添加以下依赖项。spring-doc.cn

Fabric8 实现spring-doc.cn

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-kubernetes-fabric8-loadbalancer</artifactId>
</dependency>

Kubernetes Java 客户端实现spring-doc.cn

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-kubernetes-client-loadbalancer</artifactId>
</dependency>

要启用基于 Kubernetes Service 名称的负载均衡,请使用以下属性。然后负载均衡器将尝试使用 address 调用应用程序,例如service-a.default.svc.cluster.localspring-doc.cn

spring.cloud.kubernetes.loadbalancer.mode=SERVICE

要跨所有命名空间启用负载均衡,请使用以下属性。遵循 module 中的属性。spring-cloud-kubernetes-discoveryspring-doc.cn

spring.cloud.kubernetes.discovery.all-namespaces=true

如果需要通过 HTTPS 访问服务,则需要在服务定义中添加带有名称和值的标签或注释,然后负载均衡器将使用 HTTPS 向服务发出请求。securedtruespring-doc.cn