前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringCloud服务比较快的下线配置

SpringCloud服务比较快的下线配置

作者头像
叔叔
发布2018-04-11 12:59:51
2.7K0
发布2018-04-11 12:59:51
举报
文章被收录于专栏:叔叔的博客叔叔的博客

一、前言

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

二、配置

  1. Eureka Server配置
代码语言:javascript
复制
# 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配置
代码语言:javascript
复制
eureka.instance.lease-expiration-duration-in-seconds=15
eureka.instance.lease-renewal-interval-in-seconds=5
eureka.client.registryFetchIntervalSeconds=5

三、吐槽

代码语言:javascript
复制
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%怠机了。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-04-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 叔叔的博客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、前言
  • 二、配置
  • 三、吐槽
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档