一 SpringCloud Eureka自我保护机制
Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 会将这些实例保护起来,让这些实例不会过期,但是在保护期内如果服务刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,此时会调用失败,对于这个问题需要服务消费者端要有一些容错机制,如重试,断路器等。
我们在单机测试的时候很容易满足心跳失败比例在 15 分钟之内低于 85%,这个时候就会触发 Eureka 的保护机制,一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了,此时我们可以使用eureka.server.enable-self-preservation=false来关闭保护机制,这样可以确保注册中心中不可用的实例被及时的剔除。虽然这样做并不被推荐,但是在项目开发测试期间这样做还是很有必要的。
二 详细配置
服务端(注册中心)如图:
客户端配置(服务提供者)如图:
还有一个服务照样这么配置。
接下来启动注册中心eureka_center,端口911,启动两个服务提供者cart-service,端口分别为2221,2222,如下图所示:
关闭2221服务,等15s刷新页面,如图所示:
发现服务被剔除了。
三 源代码中的默认配置
服务端有60秒的剔除间隔,如下图:
客户端30秒心跳,90秒失效:
以上加起来是3分钟,也就是说在关闭保护模式后,默认情况下,会有3分钟左右的剔除延迟