SpringCloud Eureka原理分析
一、Eureka的基础架构及服务治理机制
Eureka服务治理的基础架构包含三个核心:服务注册中心、服务提供者、服务消费者。其中服务注册中心,即Eureka提供的服务端,提供服务注册和发现的功能;服务提供者,即将自己的服务注册到注册中心;服务的消费者,从注册中心获取服务列表,从而使消费者知道到何处调用服务,服务消费可以使用Ribbon、Feign等。
1、服务提供者:
- 服务注册:服务提供者在项目启动时,会通过发送REST请求的方式将自己注册到eureka server上,同时带上一些自己的元数据,Eureka Server收到请求后,将元数据存储在一个双层map中,第一层的key是服务名称,第二层的key是具体的服务实例。
- 服务同步:如果A项目将服务注册到了M注册中心,B项目将服务注册到N注册中心,但是如果M项目和N项目开启了可以注册为服务的配置,那么当A项目将服务注册到M注册中心时,M注册中心会将请求转发到N注册中心,以保证两个注册中心副本中服务同步。
- 服务续约:在注册完服务后,服务提供者会维护一个心跳(30s发送一次)来持续告诉注册中心其还活着,以防止注册中心的剔除任务将该服务实例从服务列表中删除。
关于心跳频率与剔除任务认为服务失效时间的配置参数如下所示(配置值均为默认值):
eureka:
instance:
# 心跳检测频率
lease-renewal-interval-in-seconds: 30
# 服务失效时间
lease-expiration-duration-in-seconds: 90