博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Eureka自我保护模式——难点重点
阅读量:6220 次
发布时间:2019-06-21

本文共 2553 字,大约阅读时间需要 8 分钟。

一、开启Eureka自我保护模式

访问Eureka主页时,如果看到这样一段大红色的句子:

EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY’RE NOT. RENEWALS ARE LESSER THAN THRESHOLD AND HENCE THE INSTANCES ARE NOT BEING EXPIRED JUST TO BE SAFE.

那么表明Eureka的自我保护模式是启动的。

解决这种情况的方法主要有几种方式:

1. 等待 Eureka Server 自动恢复
正常的情况下,等待网络恢复(或者没有频繁的启动与关闭实例)后,等待一段时间 Eureka Server 会自动关闭自我保护模式,但是如果它迟迟没有关闭该模式,那么便可以尝试手动关闭,如下。

2. 重启 Eureka Server

通常而言,PRD 环境建议对 Eureka Server 做负载均衡,这样在依次关闭并开启 Eureka Server 后,无效的实例会被清除,并且不会对正常的使用照成影响。

3. 关闭 Eureka 的自我保护模式

后面介绍

二、Eureka自我保护模式原理

默认情况下,如果在15分钟内超过85%的客户端节点都没有正常的心跳,那么Eureka就认为客户端与注册中心出现了网络故障(比如网络故障或频繁的启动关闭客户端),Eureka Server自动进入自我保护模式。不再剔除任何服务,当网络故障恢复后,该节点自动退出自我保护模式。

eureka:  server:    #自我保护模式,当出现网络分区故障、频繁的开启关闭客户端、eureka在短时间内丢失过多客户端时,会进入自我保护模式,即一个服务长时间没有发送心跳,eureka也不会将其删除,默认为true    enable-self-preservation: true    #eureka server清理无效节点的时间间隔,默认60000毫秒,即60秒    eviction-interval-timer-in-ms: 60000    #阈值更新的时间间隔,单位为毫秒,默认为15 * 60 * 1000    renewal-threshold-update-interval-ms: 15 * 60 * 1000    #阈值因子,默认是0.85,如果阈值比最小值大,则自我保护模式开启    renewal-percent-threshold: 0.85    #清理任务程序被唤醒的时间间隔,清理过期的增量信息,单位为毫秒,默认为30 * 1000    delta-retention-timer-interval-in-ms: 30000

自我保护模式是一种对网络异常的安全保护措施。使用自我保护模式让Eureka集群更加的健壮、稳定。

三、关闭 Eureka 的自我保护模式

可以使用eureka.server.enable-self-preservation=false来禁用自我保护模式,适合在开发/测试环境中使用,生产环境建议打开自我保护模式。

对于开发/测试环境的 Eureka Server,个人更建议关闭它的自我保护模式,因为你可能需要不断的开启与关闭实例,如果并未关闭自我保护模式,那么很容易就会触发自我保护模式,此时对调试会相对比较麻烦。

但是关闭自我保护模式,会有另外一个可能的问题,即隔一段时间后,可能会发生实例并未关闭,却无法通过网关访问了,此时很可能是由于网络问题,导致实例(或网关)与 Eureka Server 断开了连接,Eureka Server 已经将其注销(网络恢复后,实例并不会再次注册),此时重启 Eureka Server 节点或实例,并等待一小段时间即可。

关闭自我保护模式,可以在服务端和客户端配置。

服务端配置:eureka:  server:    enable-self-preservation: false    #eureka server清理无效节点的时间间隔,默认60000毫秒,即60秒    eviction-interval-timer-in-ms: 60000 # 单位毫秒客户端配置:# 心跳检测检测与续约时间# 测试时将值设置设置小些,保证服务关闭后注册中心能及时踢出服务eureka:  instance:    lease-renewal-interval-in-seconds: 1    lease-expiration-duration-in-seconds: 2
配置说明 lease-renewal-interval-in-seconds 每间隔1s,向服务端发送一次心跳,证明自己依然”存活“。lease-expiration-duration-in-seconds  告诉服务端,如果我2s之内没有给你发心跳,就代表我“死”了,请将我踢掉。

四、Eureka的健康检查

说明:在Status栏显示着UP,表示应用程序状态正常。其它取值DOWN、OUT_OF_SERVICE、UNKNOWN等,只有UP的微服务会被请求。

由于Eureka Server与Eureka Client之间使用心跳机制来确定Eureka Client的状态,默认情况下,服务器端与客户端的心跳保持正常,应用程序就会始终保持“UP”状态,所以微服务的UP并不能完全反应应用程序的状态。

Spring Boot Actuator提供了/health端点,该端点可展示应用程序的健康信息,只有将该端点中的健康状态传播到Eureka Server就可以了,实现这点很简单,只需为微服务配置如下内容:

#开启健康检查(需要spring-boot-starter-actuator依赖)

eureka.client.healthcheck.enabled = true

如果需要更细粒度健康检查,可实现com.netflix.appinfo.HealthCheckHandler接口 。 EurekaHealthCheckHandler 已实现了该接口

转载地址:http://ytoja.baihongyu.com/

你可能感兴趣的文章
Light Life 小组Alfha冲刺(第二天)
查看>>
Miller_Rabin (米勒-拉宾) 素性测试
查看>>
【转载】比较排序算法
查看>>
DBUtils
查看>>
java spring cloud版b2b2c社交电商spring cloud分布式微服务-docker-feign-hystrix(六)
查看>>
html之一行代码给table设置标题...
查看>>
(转)超简单的缓存实现
查看>>
26日上午多家网站因DNS故障无法访问 包括CCTV、网易等知名网站
查看>>
java实现动态代理切面编程
查看>>
ros自定义消息
查看>>
Python编码问题整理
查看>>
TranslateAnimation详解
查看>>
TP5 未定义数组索引如何解决
查看>>
android ListView下拉刷新之功能实现
查看>>
开始学习 ubuntu 14.04 各种安装各种坑
查看>>
Java后台使用Websocket教程
查看>>
go语言学习--string、int、int64互相转换,字符串的截取,数组和字符串的转换
查看>>
Linux下添加新硬盘,分区及挂载
查看>>
js复选框全选反选
查看>>
JAVA 关键字及其作用解释
查看>>