135. Kubernetes 的 DiscoveryClient

该项目为Discovery Client提供了Kubernetes的实现。这使您可以按名称查询 Kubernetes 端点 (请参阅services) 。 Kubernetes API 服务器通常将服务公开为一组端点,这些端点表示 Client 端可以从作为 Pod 运行的 Spring Boot 应用程序访问的httphttps地址。 Spring Cloud Kubernetes Ribbon 项目还使用此发现功能来获取为要进行负载平衡的应用程序定义的端点列表。

只需在项目内部添加以下依赖项,便可以免费获得这些东西:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-kubernetes</artifactId>
    <version>${latest.version}</version>
</dependency>

要启用DiscoveryClient的加载,请将@EnableDiscoveryClient添加到相应的配置或应用程序类中,如下所示:

@SpringBootApplication
@EnableDiscoveryClient
public class Application {
  public static void main(String[] args) {
    SpringApplication.run(Application.class, args);
  }
}

然后,您可以通过以下方式简单地将 Client 端注入代码中:

@Autowired
private DiscoveryClient discoveryClient;

如果出于任何原因需要禁用DiscoveryClient,则只需在application.properties中设置以下属性:

spring.cloud.kubernetes.discovery.enabled=false

一些 Spring Cloud 组件使用DiscoveryClient来获取有关本地服务实例的信息。为此,您需要将 Kubernetes 服务名称与spring.application.name属性对齐。