1.EurekaClient向EurekaServer注册时,和EurekaSever有续约时间和剔除时间的约定,默认30秒续约一次,如果90秒还没有续约就可以剔除掉我,把时间设置成2和4

server:
  port: 8000
spring:
  application:
    name: user

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    #和房东续约时间,默认30秒
    leaseRenewalIntervalInSeconds: 2
    #多久不交房租就被剔除,默认90秒
    lease-expiration-duration-in-seconds: 4

2.EurekaSever启动时会启动一个剔除定时任务,默认60秒执行一次,当EurekaServer在执行剔除任务时发现有需要被剔除的EurekaClient会做剔除操作,把时间设置为2000

server:
  port: 8761

eureka:
  server:
    enableSelfPreservation: false
    #多久执行一次剔除任务,默认时60秒
    eviction-interval-timer-in-ms: 2000
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://localhost:${server.port}/eureka/

3.可以通过EurekaServer提供的Restful接口把EurekaClient实例的状态变成OUT_OF_SERVICE状态,如果服务点拿到这个状态后就不会发送请求了
https://github.com/Netflix/eureka/wiki/Eureka-REST-operations

Take instance out of service  PUT /eureka/v2/apps/appID/instanceID/status?value=OUT_OF_SERVICE	
HTTP Code:
* 200 on success
* 500 on failure
PUT类型方法  http://localhost:8761/eureka/apps/USER/127.0.0.1:user:8000/status?value=OUT_OF_SERVICE

4.判断是否更新成功,如果更新成功睡眠10s后把应用kill掉

5.流程

在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐