SpringCloud服务比较快的下线配置

时间:2022-05-08
本文章向大家介绍SpringCloud服务比较快的下线配置,主要内容包括一、前言、二、配置、三、吐槽、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

一、前言

想实现热部署,需要服务很快的上下线,所以需要修改相关配置。

二、配置

  1. Eureka Server配置
# 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
  1. Eureka Client配置
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%怠机了。