SpringCloud服务比较快的下线配置
时间:2022-05-08
本文章向大家介绍SpringCloud服务比较快的下线配置,主要内容包括一、前言、二、配置、三、吐槽、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
一、前言
想实现热部署,需要服务很快的上下线,所以需要修改相关配置。
二、配置
- 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
- 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%怠机了。
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- 【自动化测试】【Jest-Selenium】(02)—— Jest 匹配器
- 【自动化测试】【Jest-Selenium】(03)—— Jest 异步测试
- 【自动化测试】【Jest-Selenium】(04)—— Selenium WebDriver
- 前端开发"模块打包器"webpack4实战入门
- shadow dom一个最简单的例子
- 程序员必读:Git提交信息和分支创建规范
- 使用brew cask安装minikube的各种错误和解决方法
- 编写高质量可维护的代码:一目了然的注释
- SAP Hybris - how to find corresponding cronjob for a given import
- Linux与Windows间文件互传之TFTP方式
- 假设检验在数据分析中的应用
- 【前端开发】文本阴影:如何使用text-shadow实现首字线索引效果?
- 9.25【前端开发】超链接伪类:如何在svg元素上使用超链接伪类?
- 竞赛比完,代码、模型怎么处理?Kaggle大神:别删,这都是宝藏
- 9.26【前端开发】背景属性:样式中背景色和背景图片样式如何使用?