失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > eureka自我保护时间_Spring Cloud Eureka 自我保护机制

eureka自我保护时间_Spring Cloud Eureka 自我保护机制

时间:2019-08-31 20:57:13

相关推荐

eureka自我保护时间_Spring Cloud Eureka 自我保护机制

自我保护出现

首先对Eureka注册中心需要了解的是Eureka各个节点都是平等的,没有ZK中角色的概念, 即使N-1个节点挂掉也不会影响其他节点的正常运行。

默认情况下,如果Eureka Server在一定时间内(默认90秒)没有接收到某个微服务实例的心跳,Eureka Server将会移除该实例。但是当网络分区故障发生时,微服务与Eureka Server之间无法正常通信,而微服务本身是正常运行的,此时不应该移除这个微服务,所以引入了自我保护机制。

自我保护机制

官方对于自我保护机制的定义:

简单 来说 :Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 会将这些实例保护起来,让这些实例不会过期,但是在保护期内如果服务刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,此时会调用失败,对于这个问题需要服务消费

者端要有一些容错机制,如重试,断路器等

我们在单机测试的时候很容易满足心跳失败比例在 15 分钟之内低于 85%,这个时候就会触发 Eureka 的保护机制,一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了,此时我们可以使用eureka.server.enable-self-preservation=false来关闭保护机制,这样可以确保注册中心中不可用的实例被及时的剔除(不推荐)。

自我 保护机制 的设置

Eureka自我保护机制,通过配置eureka.server.enable-self-preservation来true打开/false禁用自我保护机制,默认打开状态,建议生产环境打开此配置。

开发时的配置

1、 注册中心关闭自我保护机制,修改检查失效服务的时间

eureka:

server:

enable-self-preservation: false

eviction-interval-timer-in-ms: 3000

2、 微服务修改减短服务心跳的时间。

# 默认90秒

lease-expiration-duration-in-seconds: 10

# 默认30秒

lease-renewal-interval-in-seconds: 3

以上配置建议在生产环境使用默认的时间配置。

如果觉得《eureka自我保护时间_Spring Cloud Eureka 自我保护机制》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。