Eureka自我保护机制及服务离线
在前几篇中《创建Eureka服务中心》我们介绍了Eureka的心跳检测并创建了Eureka服务中心,本篇将承接前面的内容讲解Eureka的自我保护机制以及离线服务。
自我保护机制
通过阅读Eureka官网体系架构图下方的文档我们能够知道,eureka客户端,默认会每隔30秒发送一次心跳的eureka注册中心,如果在90秒内没收到一个eureka客户端的心跳,那么就摘除这个服务实例,消费者将无法访问这个服务实例了。
但是很多情况下不是微服务节点有问题,而是出现了网络抖动等原因导致EurekaServer无法发现该微服务(检测不到该微服务主机的心跳),从而摘除这个服务实例。
如果在短时间内EurekaServer摘除掉了较多的微服务(收到的心跳数量小于阈值),那么为了保证系统的可用性(AP),那些由于网络抖动被摘除的服务实例将会“复活”,Eureka自动进入自我保护模式。
(服务列表只可读取、写入,不可执行删除操作。当EurekaServer收到的心跳数量恢复到阈值以上时,其会自动退出自我保护模式。)
自我保护模式是自动开启的,可以在eurekaserver的配置文件中关闭,不建议关闭!(除非处于特殊状态,例如:测试)
# 关闭自我保护机制 eureka.server.enable-self-preservation: false12复制代码类型:[java]
关闭自我保护机制后可以设置server端剔除不可用服务的时间
# 设置server端剔除不可用服务的时间窗,单位毫秒 eureka.server.eviction-interval-timer-in-ms: 500012复制代码类型:[java]
也可以修改不同服务实例发送心跳的周期
# 设置当前Client每1秒向Server发送一次心跳,单位秒 eureka.server.lease-renewal-interval-in-seconds: 112复制代码类型:[java]
指定让Server认定当前Client已经失效的时间
# 指定让Server认定当前Client已经失效的时间,将来可以从注册表中剔除了,单位秒 eureka.server.lease-expiration-duration-in-seconds: 312复制代码类型:[java]
自我保护的阈值因子默认为0.85,也就是说当EurekaServer接收到的心跳数量小于85%时自我保护机制就会自动开启。自我保护的阈值因子也可以在eurekaserver的配置文件中根据需求进行自定义。
# 自定义自我保护的阈值,默认为0.85eureka.server.renewal-percent-threshold: 0.6512复制代码类型:[java]
配置完成后执行代码,刷新浏览器
红色的提示信息不会在访问马上出来。
自我保护模式被激活的条件是:在1分钟后
Renews(lastmin)<Renewsthreshold
Renewsthreshold:EurekaServer期望每分钟收到客户端实例续约的总数。
Renews(lastmin):EurekaServer最后1分钟收到客户端实例续约的总数。
Renewsthreshold计算代码:
this.expectedNumberOfRenewsPerMin = count * 2;this.numberOfRenewsPerMinThreshold = (int) (this.expectedNumberOfRenewsPerMin * serverConfig.getRenewalPercentThreshold());12复制代码类型:[java]
如果在1分钟后,Renews(lastmin)<Renewsthreshold,默认需等待5分钟(可以通过eureka.server.wait-time-in-ms-when-sync-empty配置),即5分钟后你会看到红色的提示信息。
服务下线
服务离线是指服务不能再对外提供服务了。
服务离线的原因有两种:
服务下架与服务下线,这两种方案都是基于Actuator监控器实现的。
服务下架:将注册到EurekaServer中的EurekaClient从Server的注册表中移除,这样其它Client就无法发现该Client了。
服务下线:Client并没有从EurekaServer的注册表中移除(其它Client仍可发现该服务),而是通过修改服务的状态来到达其它Client无法调用的目的。
首先为EurekaClient添加actuator依赖。
在provider和consumer的pom文件中添加spring-boot-starter-actuator依赖。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>1234复制代码类型:[java]
服务下架
修改provider的配置文件。
management: # 开启所有监控终端 endpoints: web: exposure: include: "*" # 开启shutdown监控终端 endpoint: shutdown: enabled: true12345678910复制代码类型:[java]
执行代码,在postman中访问
http://localhost:8081/actuator/shutdown
服务下架后EurekaClient从Server的注册表中彻底移除,再次使用时需要重新启动。但是对于大型应用来说比较耗时的,所以希望服务可以平滑上/下线。
服务平滑上/下线
配置文件只需将shutdown监控终端部分注释掉。
执行代码,在postman中访问
http://localhost:8081/actuator/service-registry
将状态自定义为DOWN。
回到浏览器查看服务状态。
此时Client无法调用。
将状态DOWN改成UP就可以实现平滑上线。
{ "status":"UP"}123复制代码类型:[java]
平滑上线之后,consumer需要等待一会儿才能正常访问。因为Client下载注册表每三十秒更新一次,consumer启动时,注册表可能还没有更新。