spring-cloud-kubernetes背后的三个关键知识点

首先为自己打个广告,我目前在某互联网公司做架构师,已经有5年经验,每天都会写架构师系列的文章,感兴趣的朋友可以关注我和我一起探讨,关注我,免费分享Java基础教程,以及进阶的高级Java架构师教程,全部免费送

概览

总结下来有三个关键知识点需要深入理解:

1、DiscoveryClient是个接口,对应的实现类是哪个?

2、
discoveryClient.getServices()方法取得了kubernetes的service信息,这背后的机制是什么?java应用是怎样取得所在kubernetes的服务信息的?

3、kubernetes的service信息存在哪里?如何将这些信息给出去?

接下来我们逐一分析每个知识点;

DiscoveryClient接口的实现类实例从何而来

先来回顾一下上一章的DiscoveryController.java的内容:

@RestController
public class DiscoveryController {
 @Autowired
 private DiscoveryClient discoveryClient;
 /**
 * 探针检查响应类
 * @return
 */
 @RequestMapping("/health")
 public String health() {
 return "health";
 }
 /**
 * 返回远程调用的结果
 * @return
 */
 @RequestMapping("/getservicedetail")
 public String getUri(
 @RequestParam(value = "servicename", defaultValue = "") String servicename) {
 return "Service [" + servicename + "]'s instance list : " + JSON.toJSONString(discoveryClient.getInstances(servicename));
 }
 /**
 * 返回发现的所有服务
 * @return
 */
 @RequestMapping("/services")
 public String services() {
 return this.discoveryClient.getServices().toString()
 + ", "
 + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
 }
}

上述代码中,我们并没有写创建DiscoveryClient实例的代码,discoveryClient从何而来?

这一切,要从DiscoveryController.java所在项目的pom.xml说起;

1、在pom.xml中,有对spring-cloud-kubernetes框架的依赖配置:

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-kubernetes-discovery</artifactId>
 <version>1.0.1.RELEASE</version>
</dependency> 

2、打开
spring-cloud-kubernetes-discovery的源码,地址是:https://github.com/spring-cloud/spring-cloud-kubernetes/tree/master/spring-cloud-kubernetes-discovery ,在这个工程中发现了文件spring.factories:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值