一、 服务提供者的配置
服务提供者要向EurekaServer注册服务,并且完成服务续约等工作。
1、 服务注册
服务提供者在启动时,会检测配置属性中的:
eureka.client.register-with-erueka=true
参数是否正确,
事实上默认就是true。如果值确实为true,则会向EurekaServer发起一个Rest请求,并携带自己的数据信息,Eureka Server会把这些信息保存到一个双层Map结构中。第一层Map的Key就是服务名称,第二层Map的key是服务的实例id。
2、 服务续约
在注册服务完成以后,服务提供者会维持一个心跳(定时向EurekaServer发起Rest请求)。这个我们称为服务的续约(renew);
3、修改续约
#配置服务端
eureka:
instance:
lease-expiration-duration-in-seconds: 90 #服务失效时间
lease-renewal-interval-in-seconds: 30 #续约时间
#ease-renewal-interval-in-seconds:服务续约(renew)的间隔,默认为30秒
#lease-expiration-duration-in-seconds:服务失效时间,默认值90秒
4、 实例id
Eureka监控页面status信息:
- UP(1):代表现在是启动了1个示例,没有集群
- DESKTOP-2MVEC12:user-service:8081:是实例的名称(instance-id),
- 默认格式是:
${hostname} + ${spring.application.name} + ${server.port}
- instance-id是区分同一服务的不同实例的唯一标准,因此不能重复。
可以通过instance-id属性来进行修改
eureka:
instance:
instance-id: ${spring.application.name}:${server.port}
二、服务消费者的配置
1、获取服务列表
当服务消费者启动时,会检测eureka.client.fetch-registry=true
参数的值,
如果为true,则会从Eureka Server服务的列表只读备份,然后缓存在本地。并且每隔30秒
会重新获取并更新数据。
eureka:
client:
registry-fetch-interval-seconds: 5 #默认30秒
三、eureka注册中心的配置
server:
port: 8888
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:8888 #对外服务的路径(注册服务的路径)
fetch-registry: false #不拉取服务列表
registerWithEureka: false #不要把自己注册成了服务
spring:
application:
name: eureka-server
1、失效剔除
有些时候,我们的服务提供方并不一定会正常下线,可能因为内存溢出、网络故障等原因导致服务无法正常工作。
Eureka Server需要将这样的服务剔除出服务列表。因此它会开启一个定时任务,每隔60秒对所有失效的服务(超过90秒未响应)进行剔除。
可以通过eureka.server.eviction-interval-timer-in-ms
参数对其进行修改,单位是毫秒,生成环境不要修改。
你对服务重启,隔了60秒Eureka才反应过来。开发阶段可以适当调整,比如10S
2、自我保护
这是触发了Eureka的自我保护机制。当一个服务未按时进行心跳续约时,
Eureka会统计最近15分钟心跳失败的服务实例的比例是否超过了85%。
在生产环境下,因为网络延迟等原因,心跳失败实例的比例很有可能超标,但是此时就把服务剔除列表并不妥当,
因为服务可能没有宕机。
Eureka就会把当前实例的注册信息保护起来,不予剔除。生产环境下这很有效,保证了大多数服务依然可用。
eureka:
server:
enable-self-preservation: false # 关闭自我保护模式(缺省为打开)
eviction-interval-timer-in-ms: 1000 # 扫描失效服务的间隔时间(缺省为60*1000ms)