【微服务~原始真解】Spring Cloud —— Eureka Client原码解析(二)_eurekaeventlistener

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

主要介绍Spring Cloud —— Eureka Client原码解析(二)

文章目录

服务发现客户端

为了对Eureka Client的执行原理进行讲解,首先需要对服务发现客户端com.netflix.discover.DiscoveryClient职能以及相关类进行讲解,它负责了与EurekaServer交互的关键逻辑。

1.DiscoveryClient职责

DiscoveryClient是Eureka Client的核心类,包括与Eureka Server交互的关键逻辑,具备了以下职能:

  • 注册服务实例到Eureka Server中;
  • 发送心跳更新与Eureka Server的租约;
  • 在服务关闭时从Eureka Server中取消租约,服务下线;
  • 查询在Eureka Server中注册的服务实例列表。
2.DiscoveryClient类结构

DiscoverClient的核心类图如图所示。
在这里插入图片描述
DiscoveryClient继承了LookupService接口,LookupService作用是发现活跃的服务实例,主要方法如下:

//LookupService. java
public interface LookupService<T> {
//根据服务实例注册的appName来获取封装有相同appName的服务实例信息容器Application getApplication(String appName) ;
//返回当前注册表中所有的服务实例信息
Applications getApplications () ;//根据服务实例的id获取服务实例信息
List<InstanceInfo> getInstancesById(String id) ;
}

Application持有服务实例信息列表,它可以理解成同一个服务的集群信息,这些服务实例都挂在同一个服务名appName下。InstanceInfo代表一个服务实例信息。
Application部分代码如下:

//Application. java
public class Application {
private static Random shuffleRandom = new Random() ;
//服务名
private String name;
@XStream0mitField
private volatile boolean isDirty = false;
@XStreamImplicit
private final Set<InstanceInfo> instances;
private final AtomicReference <List<InstanceInfo>> shuffledInstances;
private final Map<String, InstanceInfo> instancesMap;
}


为了保证原子性操作,Application中对Instancelnfo的操作都是同步操作。

Applications是注册表中所有服务实例信息的集合,里面的操作大多也是同步操作。

EurekaClient继承了LookupService接口,为DiscoveryClient提供了一个上层接口,目的是方便从Eureka 1.x到Eureka 2.x(已停止开发)的升级过渡。EurekaClient接口属于比较稳定的接口,即使在下一阶段也会被保留。

EurekaCient在LookupService的基础上扩充了更多的接口,提供了更丰富的获取服务实例的方式,主要有:

  • 提供了多种方式获取Instancelnfo,例如根据区域、Eureka Server地址等获取。
  • 提供了本地客户端(所处的区域、可用区等)的数据,这部分与AWS密切相关。
  • 提供了为客户端注册和获取健康检查处理器的能力。

除去查询相关的接口,我们主要关注EurekaClient中以下两个接口,代码如下所示:

// EurekaClient.java
//为Eureka Client注册健康检查处理器
public void registerHealthCheck(HealthCheckHandler healthCheckHandler);
//为Eureka Client注册一个EurekaEventListener(事件监听器)
//监听Client服务实例信息的更新
public void registerEventListener(EurekaEventListener eventListener);


Eureka Server一般通过心跳(heartbeats)来识别一个实例的状态。EurekaClient中存在一个定时任务定时通过HealthCheckHandler检测当前Client的状态,如果Client的状态发生改变,将会触发新的注册事件,更新Eureka Server的注册表中该服务实例的相关信息。HealthCheckHandler的代码如下所示:

// HealthCheckHandler.java
public interface HealthCheckHandler {
InstanceInfo.InstanceStatus getStatus (InstanceInfo.InstanceStatus currentStatus) ;
}

HealthCheckHandler接口的代码如上所示,其在spring-cloud-netflix-eureka-client中的实现类为EurekaHealthCheckHandler,主要组合了spring-boot-actuator中的HealthAggregator和HealthIlndicator,以实现对Spring Boot应用的状态检测。
Eureka中的事件模式属于观察者模式,事件监听器将监听Client的服务实例信息变化,触发对应的处理事件,下图为Eureka事件的类图:
在这里插入图片描述

3.DiscoveryClient

DiscoveryClient可以说是Eureka Client的核心类,负责了与Eureka Server交互的关键逻辑,具备了以下的职能:

  • 注册服务实例到Eureka Server中;
  • 更新与Eureka Server的契约;
  • 在服务关闭时从Eureka Server中取消契约;
  • 查询在Eureka Server中注册的服务/实例的列表。

DiscoverClient的核心类图如下:
在这里插入图片描述

DiscoveryClient的顶层接口为LookupService,主要的目的是为了发现活跃中的服务实例。

public interface LookupService<T> {
 
	//根据服务实例注册的appName来获取,获取一个封装有相同appName的服务实例信息的容器
   Application getApplication(String appName);
	//返回当前注册的所有的服务实例信息
   Applications getApplications();
   	//根据服务实例的id获取
   	List<InstanceInfo> getInstancesById(String id);
   //获取下一个可能的Eureka Server来处理当前对注册表信息的处理,一般是通过循环的方式来获取下一个Server
   InstanceInfo getNextServerFromEureka(String virtualHostname, boolean secure);
}

Application中持有一个特定应用的多个实例的列表,可以理解成同一个服务的集群信息,它们都挂在同一个服务名appName下,InstanceInfo代表一个服务实例,部分代码如下:

public class Application {
    
    private static Random shuffleRandom = new Random();
 
    //服务名
    private String name;
 
    @XStreamOmitField
    private volatile boolean isDirty = false;
 
    @XStreamImplicit
    private final Set<InstanceInfo> instances;
 


![img](https://img-blog.csdnimg.cn/img_convert/9b79c642c0040820557e9fdca50de314.png)
![img](https://img-blog.csdnimg.cn/img_convert/b5a7521416ba797db2c0dec22d1db0ed.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**

的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值