文章目录
一、Eureka没有注销过期的实例问题
1.方案一
Eureka 通过心跳续约机制来维持和其他实例的通信。实例每30秒会向Eureka Server发送一次心跳,若Eureka Server (默认)90秒内没有收到实例的心跳,就会注销该实例。
很有可能因为注销的时间没有过,导致过期微服务依然显示在Eureka注册列表,可以多等一段时间。
修改实例续约发送的时间及注销时间
#客户端配置
eureka:
instance:
lease-renewal-interval-in-seconds: 1 #每一秒发送一次续约
lease-expiration-duration-in-seconds: 2 #两秒没有收到续约将其注销
注意:正式环境使用Eureka 默认配置即可
2.方案二
若长时间Eureka依然没有注销已过期的实例,那就是Eureka的自我保护机制作祟了。
上文所讲Eureka会将90秒内没有心跳的实例注销掉。在一些特殊情况下网络发生故障时,Eureka与实例无法正常通信,接收不到心跳续约就可能把健康的实例注销掉。为了应对此类问题,Eureka可通过’'自我保护模式"来解决这个问题。
自我保护机制:在短时间内Eureka丢失多个实例时就会开启自我保护机制(15分钟内丢失85%的实例续约就会开启)
自我保护机制Netflix的官方解释:
https://github.com/Netflix/eureka/wiki/Understanding-Eureka-Peer-to-Peer-Communication
在开发环境中为了快速测试可以将Eureka的自我保护机制手动关闭,正式环境推荐默认打开(保护服务的健壮性)
关闭方式:在Eureka Server 配置文件中添加eureka.server.enable-self-preservation: false
配置即可关闭保护机制
#服务端配置
eureka:
client: