想实现热部署,需要服务很快的上下线,所以需要修改相关配置。
# eureka server刷新readCacheMap的时间,client读取的是readCacheMap,默认30s
eureka.server.responseCacheUpdateInvervalMs=3000
#缓存readWriteCacheMap失效时间,因为开启了evict,这个就没起到作用了,默认180s
eureka.server.responseCacheAutoExpirationInSeconds=180
# 服务下线任务定时,默认60s
eureka.server.eviction-interval-timer-in-ms=3000
# 超过这个时间没收到心跳就剔除这个服务,这个配置一般为服务刷新时间配置的三倍,默认90s
eureka.instance.lease-expiration-duration-in-seconds=15
# 服务刷新时间,默认30s
eureka.instance.lease-renewal-interval-in-seconds=5
# eureka client刷新本地缓存时间,默认30s
eureka.client.registryFetchIntervalSeconds=5
# 关闭自我保护
eureka.server.enable-self-preservation=false
eureka.instance.lease-expiration-duration-in-seconds=15
eureka.instance.lease-renewal-interval-in-seconds=5
eureka.client.registryFetchIntervalSeconds=5
if (this.expectedNumberOfRenewsPerMin > 0) {
// Since the client wants to cancel it, reduce the threshold
// (1
// for 30 seconds, 2 for a minute)
this.expectedNumberOfRenewsPerMin = this.expectedNumberOfRenewsPerMin + 2;
this.numberOfRenewsPerMinThreshold =
(int) (this.expectedNumberOfRenewsPerMin * serverConfig.getRenewalPercentThreshold());
}
这里是Eureka的自我保护机制,每注册上一个实例,重新算一下。
默认是每30秒一个client心跳一次,一分钟就是两次,这里加一个实例,就是加2次,硬编码了,所以都说尽量不要改心跳时间配置。
可是按照springcloud的推荐默认配置,服务下线,最多还能访问90+30=120s。
有说让服务优雅下线,但这样也就是不能做到100%怠机了。