Eureka Server开关流程

       Eureka Server 是 Netflix 开发的注册中心,Eureka Server 的配置搭建比较简单,通过一个简单的依赖,再通过在启动类上增加一个注解,还有简单的配置文件就可以了。那 SpringBoot 的项目是如何通过注解变成注册中心呢?其实流程比较简单,本文简单的整理了一下它的开关流程。

Eureka Server 开关流程

        使用 Eureka Server 时需要引入 Eureka Server 的 starter 依赖 spring-cloud-starter-netflix-eureka-server,这是最基本的一步。通过该 starter 依赖,Maven 会自动的下载其相关具体依赖,Eureka Server 的具体依赖是 spring-cloud-netflix-eureka-server。通过该依赖的 Jar 包中可以找到 spring.factories 的配置,该配置文件如下:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
  org.springframework.cloud.netflix.eureka.server.EurekaServerAutoConfiguration

       通过上面的配置文件,我们来查找 EurekaServerAutoConfiguration 这个类。打开该类以后,在该类上有一个注解,该注解如下:

@ConditionalOnBean({Marker.class})

        到这一步就基本可以确定是否加载 EurekaServerAutoConfiguration 这个类了。

        接着,我们去看一下 @EnableEurekaServer 这个注解,该注解有一个 @Import 的注解,如下:

@Import({EurekaServerMarkerConfiguration.class})

       此时,看一下 EurekaServerMarkerConfiguration 这个类,代码如下:

public class EurekaServerMarkerConfiguration {
    public EurekaServerMarkerConfiguration() {
    }

    @Bean
    public EurekaServerMarkerConfiguration.Marker eurekaServerMarkerBean() {
        return new EurekaServerMarkerConfiguration.Marker();
    }

    class Marker {
        Marker() {
        }
    }
}


     从代码中可以看出,整个类什么具体的事都没有做,只实例化了一个 Marker 类。

        回到 @EnableEurekaServer 注解前面的流程,有一个 @ConditionalOnBean 的注解,该注解就表示如果内存中有 Market.class 类,则加载 EurekaServerAutoConfiguration 类,这样整个流程就串起来了。

小结

       上面的代码简单的看了 SpringBoot 项目如何变成 Eureka Server 的开关,这里我整理了一个简单的流程图,希望可以对大家有所帮助。

图片

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Eureka Server是Netflix开源的服务发现组件,用于实现微服务架构中的服务注册与发现。它充当了服务注册中心的角色,负责管理所有微服务的注册信息,并提供查询、监控等功能。 Eureka Client是基于Eureka Server的客户端,用于将自己的服务注册到Eureka Server上,并从Eureka Server上获取其他服务的信息。它可以自动地将自己的服务注册到Eureka Server上,并定时向Eureka Server发送心跳,以保证自己的服务状态始终可用。同时,它还可以从Eureka Server上获取其他服务的信息,以便进行服务调用。 ### 回答2: Eureka是Netflix开发的一套基于REST的服务发现系统,允许服务在运行期间注册、协调和发现。Eureka由两个主要组件构成:Eureka serverEureka client。 Eureka serverEureka系统的核心组件,它是服务注册中心。Eureka server维护着所有可用服务的信息,包括服务的实例列表、IP地址和端口号等。Eureka server还会定期检查服务的可用性,以便列表中只包含可用的服务实例。服务实例将自己注册到Eureka server,并向其发送心跳以表明自己仍然可用。Eureka server还会在服务实例出现故障或无响应时将其从列表中删除,确保调用者只会访问到可用的服务。 Eureka client是服务提供方的组件,它将自己注册到Eureka server并发送心跳以表明自己仍然可用。Eureka client会定期从Eureka server获取服务列表,以便知道哪些服务实例是可用的。一旦服务实例出现故障或无响应,Eureka client会重新注册自己以确保服务列表的正确性。 Eureka serverEureka client的结合使得我们能够轻松地实现服务的注册、发现和协调,实现服务间的高效通信。Eureka还提供了丰富的扩展点和API,允许我们自定义各种功能和策略,以满足不同场景和需求的要求。 ### 回答3: Eureka是Netflix开源的一款服务发现框架,它支持在云端部署的服务,它能够帮助我们在环境中(如微服务架构)自动化的管理和维护服务的地址,从而使各个服务之间更加高效和协作。其中,Eureka ServerEureka Client分别是Eureka的服务端和客户端。 Eureka Server是一个可用的服务注册中心,在微服务架构中,它扮演了一个重要的角色。Eureka Server负责维护注册表,所有的微服务都可以在这个注册中心注册自己,记录它们所处的地址以及端口等(在Eureka Server中他们被称之为服务实例)。 对于一个服务,当这个服务确定好自己的服务ID、服务名和服务地址等信息后,首先需要将自己注册到Eureka Server中,这样其他微服务才能够通过查询到这个服务所在的地址,来访问到这个服务。 而Eureka Client则扮演着微服务的客户端,他是整个微服务系统中向注册中心Eureka Server注册的微服务,就像是公司ERP系统那样的一个客户端,负责跟Eureka Server通信、注册微服务实例,以及从Eureka Server中查询服务实例列表等等。 在微服务架构中,微服务的数量很多。当微服务的数量越来越多时,Eureka Server作为微服务的注册中心起到了非常重要的作用,它们可以更方便的找到其他服务以及管理和协调服务。而Eureka Client则为各个微服务之间提供了一个很好的通信平台,协同运行微服务。 总之,Eureka ServerEureka Client是构成Eureka体系的两个重要组成部分,它们能够共同协作,来建立一个高效的微服务体系,为现代化的应用架构提供了必要的支持。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农UP2U

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值