用于微服务架构中的服务治理;用作服务的注册中心;
Eureka Server:提供服务注册和发现,多个Eureka Server之间会同步数据,做到状态一致
Service Provider:服务提供方,将自身服务注册到Eureka,从而使服务消费方能够找到
Service Consumer:服务消费方,从Eureka获取注册服务列表,从而能够消费服务
服务启动后向Eureka注册,Eureka Server会将注册信息向其他Eureka Server进行同步,当服务消费者要调用服务提供者,则向服务注册中心获取服务提供者地址,然后会将服务提供者地址缓存在本地,下次再调用时,则直接从本地缓存中取,完成一次调用。
Eureka Server 三个主要功能:
如果 Eureka Server 连续 90 秒都有没有收到 Eureka Client 的续约消息(连续三次没发送),它会认为 Eureka Client 已经掉线了,会将掉线的 Eureka Client 从当前的服务注册列表中剔除。
eureka.instance.lease-renewal-interval-in-seconds # 表示服务的续约时间,默认是 30 秒。 eureka.instance.lease-expiration-duration-in-seconds # 表示服务失效时间,默认是 90 秒。
Service Provider和Service Consumer都是Euraka Client
Eureka Client 功能:
注册信息: IP 地址、端口、名称、运行状态等等
eureka.client.fetch-registry=true # 是否允许获取注册表信息 eureka.client.registry-fetch-interval-seconds=30 # Eureka Client 上缓存的服务注册信息,定期更新的时间间隔,默认 30 秒(如果 Eureka Server 返回的注册表信息与本地缓存的注册表信息不同的话,Eureka Client 会自动处理。)
从上面的分析可以得出,Eureka Client 会自动拉取、更新以及缓存
Eureka Server 中的信息,这样,即使 Eureka Server 所有节点都宕机,Eureka Client 依然能够获取到想要调用服务的地址(前提是服务地址没有发生变化)。
结论:Client 会缓存注册信息,Server突然下线并不会立马影响服务的可用性;
step1
:引入eureka-server
依赖;
org.springframework.cloud
spring-cloud-starter-netflix-eureka-server
step2
:使用@EnableEurekaServer
注解开启Eureka注册中心的功能;
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
step3
:添加Eureka注册中心的配置
server:
port: 8001 #指定运行端口
spring:
application:
name: eureka-server #指定Spring服务名称
eureka:
instance:
hostname: localhost #eureka服务端的实例名称
client:
fetch-registry: false #指定是否要从注册中心获取服务(注册中心不需要开启)
register-with-eureka: false #指定是否要注册到注册中心(注册中心不需要开启)
service-url:
# 设置与eureka server 交互的地址查询服务和注册服务都需要依赖这个地址;
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
server:
enable-self-preservation: false #关闭保护模式
step4
:配置完成后;访问 http://localhost:8001/ 能看见eureka注册中心的界面就代表搭建成功;
step1
:新建一个模块,引入eureka-client
依赖;
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
org.springframework.boot
spring-boot-starter-web
step2
:启动类上添加@EnableDiscoveryClient
注解表明是一个Eureka客户端;
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaClientApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaClientApplication.class, args);
}
}
step3
:添加Eureka注册中心的配置
server:
port: 8101 #指定运行端口
spring:
application:
name: eureka-client #服务名称
eureka:
client:
register-with-eureka: true #注册到Eureka的注册中心(默认为true)
fetch-registry: true #获取注册实例列表(默认为true)
service-url:
defaultZone: http://localhost:8001/eureka/ #配置注册中心地址(和前面server服务端的配置对应)
instance:
instance-id: test-project # 修改eureka监控页面上的服务描述信息;
step4
:配置完成后;访问 http://localhost:8001/ 能看见eureka注册中心的界面中客户端成功注册到注册中心列表则代表搭建成功;
心跳机制:微服务和Eureka Server 之间是通过心跳机制来建立连接的,如果Eureka Server在一定时间内没有收到某个微服务实例的心跳,Eureka Server将会注销该实例(默认是90s);
正常情况下,这种机制是没有问题的,但是存在一种网络分区故障的情况;当网络分区发生故障时,微服务和Eureka 之间无法正常通行,但是此时微服务本身其实是健康的(只是因为网络波动无法完成正常的通信),针对这种情况,Eureka 提供了一种 自我保护机制
自我保护机制的工作机制是如果在15分钟内超过85%的客户端节点都没有正常的心跳,那么Eureka就认为客户端与注册中心出现了网络故障,Eureka Server自动进入自我保护机制,此时会出现以下几种情况:
当Eureka Server 收到的心跳数量重新恢复到阈值以上时,Eureka Server节点就会自动退出自我保护机制;
自我保护机制的相关配置
eureka:
server:
enable-self-preservation: false # 禁用自我保护机制
eviction-interval-timer-in-ms: 3000 # 设置检查失效服务的时间为 3000
客户端修改心跳时间
eureka:
instance:
# 默认30秒(心跳的频率)
lease-renewal-interval-in-seconds: 3
Eureka Server 端修改心跳失效时间
eureka:
instance:
# 默认90秒(服务失效时间: 如果多久没有收到请求,则可以删除服务)
lease-expiration-duration-in-seconds: 10
Eureka 的集群搭建相对简单,需要准备好主机和实例,然后按照下面的步骤依次操作即可;
step1:
修改各Eureka Server实例的配置文件
# Eureka Server1
server:
port: 8001
eureka:
instance:
hostname: 192.168.XX.11 #eureka服务端的实例名称
client:
fetch-registry: false #指定是否要从注册中心获取服务(注册中心不需要开启)
register-with-eureka: false #指定是否要注册到注册中心(注册中心不需要开启)
service-url:
# 设置与eureka server 交互的地址查询服务和注册服务都需要依赖这个地址;
defaultZone: http://192.168.XX.22:8001/eureka/,http://192.168.XX.33:8001/eureka/
# Eureka Server2
server:
port: 8001
eureka:
instance:
hostname: 192.168.XX.22
client:
fetch-registry: false
register-with-eureka: false
service-url:
# 设置与eureka server 交互的地址查询服务和注册服务都需要依赖这个地址;
defaultZone: http://192.168.XX.11:8001/eureka/,http://192.168.XX.33:8001/eureka/
# Eureka Server3
server:
port: 8001
eureka:
instance:
hostname: 192.168.XX.33
client:
fetch-registry: false
register-with-eureka: false
service-url:
# 设置与eureka server 交互的地址查询服务和注册服务都需要依赖这个地址;
defaultZone: http://192.168.XX.11:8001/eureka/,http://192.168.XX.22:8001/eureka/
step2:
修改各Eureka Client实例的配置文件
eureka:
client:
service-url:
# defaultZone 配置各server端的ip+端口;之间用 “,”(逗号)分隔
defaultZone: http://192.168.XX.11:8001/eureka/,http://192.168.XX.22:8001/eureka/,http://192.168.XX.33:8001/eureka/
# http://eurekaServerIp1:port/eureka/,http://eurekaServerIp2:port/eureka/,http://eurekaServerIp3:port/eureka/
了解Eureka和Zookeeper 之间的差异之前我们先了解一下 CAP理论;
CAP理论:一个分布式系统不可能同时满足C(一致性)、A(可用性)、P(分区容错性);
P在分布式系统中是必须要保证的;
Zookeeper 保证的是 CP;
Eureka 保证的是AP;
Eureka 各个节点都是平等的,几个节点挂掉不会影响正常工作的节点;只要有一台Eureka 还在,就能保证注册服务的可用性;(只不过Eureka 查到的信息可能不是最新的注册信息)
Zookeeper 保证的是一致性,故通过Zookeeper集群 查询到的注册信息都是最新且一致的;所以Zookeeper 间需要不停的相互之间同步信息,**当Zookeeper 中master节点因为网络故障和其他的节点失去联系时,**剩余的节点会重新进行leader选举(选举的时间可能会很长),在进行leader选举的期间,整个 Zookeeper 集群是不可用的;这样就导致了Zookeeper 集群丧失了可用性;
Eureka可以很好的应对因网络故障导致部分节点失去联系的情况,不会像Zookeeper 集群那样由于master宕机,重新leader选举导致注册服务瘫痪,服务不可用的情况;