Eureka服务端

一般我们Server端会像下图一样,引入Eureka,下面就通过这个来分析Eureka服务端源码流程

一、服务端配置

@EnableEurekaServer会引入EurekaServerMarkerConfiguration类

EurekaSeverMarkerConfiguration最终会引入Marker对象,这就是一个标记对象

二、SpringBoot 加载EurekaServerAutoConfiguration

SpringBoot会在启动的时候加载 spring-cloud-netflix-eureka-server端下面的META-INF下面的EurekaServerAutoConfiguration

让我们来看看这个类

在@ConditionalOnBean这里我们就会发现当时加的Marker多有用了

三、EurekaServerAutoConfiguration和EurekaClientAutoConfiguration详解

这个类通过 @configuration和@bean,引入了很多Eureka源码中常见的组件

3.1 实例管理组件

ApplicationInfoManager 实例管理器, Eureka-server会依赖Eureka-client,Eureka client又会导入EurekaClientAutoConfiguration

这个类会导入实例管理器,

里面的实例信息为:

3.2 Eureka client实例

Eureka Server在运行的时候,也需要eureka client,因为它也需要向其他server进行网络通信

3.3 client端 服务注册组件

3.2 server端 服务发现、注册组件

完成后续的服务端启动的时候,从相邻节点拉取全量的注册表信息

3.3 集群节点管理组件

集群节点配置信息,当server端新增节点的时候,都是要向相邻节点注册上去的

3.4 eureka server上下文

Server端 接收请求组件,类似于springmvc的 controller

3.6 EurekaServer初始化组件

四、Server端完整流程(最重要)

上面这些组件都准备好了,server端就要开始启动了,看看入口在哪里,有哪些流程?

4.1 服务注册

一般来说,server启动完成后,会向其他server端进行服务注册,这一步在那里?其实就是我们上面说的

EurekaAutoServiceRegistration

它的start会完成向服务端注册

4.2 服务发现

Server端的服务发现和Client端的服务发现是不一样的,Server端的服务发现是要从相邻的server节点拉取注册表

上面不是引入一个EurekaServerInitializerConfiguration


这里非常重要,通过调用PeerAwareInstanceRegistry

的syncUp来同步相邻节点的注册表信息

相关推荐
阿里云云原生2 小时前
阿里云正式发布 RCA Benchmark,业界首个面向 Agentic Ops 的根因分析开源基准体系
云原生
marsh02064 小时前
56 openclaw与Serverless:无服务器架构下的应用实践
云原生·架构·serverless
Patrick_Wilson6 小时前
写给前端的 K8s 入门:用一张图和一个例子搞懂 5 个核心概念
云原生·kubernetes·devops
凌睿马7 小时前
离线的银河麒麟系统部署ollama
云原生·eureka
java1234_小锋7 小时前
【吊打面试官系列-ZooKeeper面试题】zookeeper 是如何保证事务的顺序一致性的?
分布式·zookeeper·云原生
my19587021357 小时前
ZooKeeper分布式协调从入门到实战
分布式·zookeeper·云原生
oioihoii7 小时前
ZooKeeper 三节点集群部署:别再单机玩,高可用强一致集群这样搭
分布式·zookeeper·云原生
云游牧者9 小时前
K8S-Helm包管理全解-从入门到Chart开发实战指南
云原生·容器·kubernetes·helm·chart模板
Elastic 中国社区官方博客10 小时前
一个查询,无限 Elasticsearch Serverless 项目:跨项目搜索介绍
大数据·elasticsearch·搜索引擎·信息可视化·云原生·serverless·全文检索
思诺学长11 小时前
从0理解Feed流系统:技术原理、架构设计与实战指南
云原生