当前位置: 首页 > news >正文

十三、超时重试机制

目录

超时配置和重试机制

FeignClient 、Ribbon 、 Hystrix三个之间配置优先级的关系

配置常用属性

Ribbon超时和重试配置:

Ribbon重试次数计算公式:

FeignClient 超时配置:

Hystrix超时配置:

Hystrix超时计算公式:


超时配置和重试机制

FeignClient 、Ribbon 、 Hystrix三个都有超时配置

FeignClient 、Ribbon 、 Hystrix三个之间配置优先级的关系

Hystrix  配置 >  FeignClient 配置 >  Ribbon 配置

配置超时时:Hystrix 超时时间 >  FeignClient超时时间 >  Ribbon 超时时间

重试机制:当网络不可达时或超时时会触发重试机制

Hystrix无重试机制,feign和ribbon都有重试机制

配置常用属性

Ribbon超时和重试配置:

#全局配置
ribbon:ConnectTimeout: 500 #请求连接的超时时间ReadTimeout: 1000 #请求处理的超时时间MaxAutoRetries: 1 #最大重试次数,当Eureka中可以找到服务,但是服务连不上时将会重试MaxAutoRetriesNextServer: 1 #切换实例的重试次数OkToRetriesOnAllOperations: true #对所有的操作请求都进行重试,如果是get则可以,如果是post、put等操作没有实现幂等的情况下是很危险的

Ribbon重试次数计算公式:

MaxAutoRetries+MaxAutoRetriesNextServer+(MaxAutoRetries*MaxAutoRetriesNextServer)

如上配置:

重试次数= 1+1+(1*1) = 3次

FeignClient 超时配置:

feign:client:config:#default代表所有服务default:#feign客户端建立连接的超时时间connect-timeout: 500#feign客户端建立连接后处理请求的超时时间read-timeout: 1000

Hystrix超时配置:

hystrix:command:#默认配置,代表所有服务default:#执行策略execution:timeout:#是否打开超时enabled: trueisolation:#资源隔离模式,默认为线程池隔离 Thread,还有一种叫信号量隔离SEMAPHOREstrategy: THREADthread:#超时时间,默认为1000mstimeoutInMilliseconds: 9000#超时时中断线程interruptOnTimeout: true#取消时候中断线程interruptOnFutureCancel: falsesemaphore:#信号量模式下的最大并发数maxConcurrentRequest: 2

Hystrix超时计算公式:

先计算ribbon的总超时时间

[ReadTimeout+(MaxAutoRetries*ReadTimeout)]*MaxAutoRetriesNextServer+1)

如上配置

[1000+(1*1000)]*(1+1)=4000ms

那么Hystrix的超时时间大于ribbon的总超时时间即可

http://www.lryc.cn/news/67715.html

相关文章:

  • JAVA常用API - Runtime和System
  • ANR实战案例 - FCM拉活启动优化
  • Kali-linux查看打开的端口
  • 判断浏览器是否支持webp图片
  • 【Qt编程之Widgets模块】-007:QTextStream类及QDataStream类
  • js对map排序,后端返回有序的LinkedHashMap类型时前端获取后顺序依旧从小到大的解决方法
  • JMX vs JFR:谁才是最强大的JVM监控利器?
  • Laravel Collection 基本使用
  • JUC并发编程19 | 读写锁
  • springboot_maven项目怎么引入mybatis
  • JAVA8的新特性——lambda表达式
  • 算法修炼之练气篇——练气六层
  • 利用GPU并行计算beta-NTI,大幅减少群落构建计算时间
  • Shiro框架漏洞分析与复现
  • (数字图像处理MATLAB+Python)第七章图像锐化-第一、二节:图像锐化概述和微分算子
  • C# | 内存池
  • 程序设计入门——C语言2023年5月10日
  • 【2023华为OD笔试必会25题--C语言版】《03 单入口空闲区域》——递归、数组、DFS
  • Grafana安装、升级与备份(02)
  • 【2023华为OD笔试必会25题--C语言版】《10 相同数字的积木游戏》——数组
  • awk命令编辑
  • Pinia和Vuex的区别
  • 《C++高并发服务器笔记——第四章Linux网络编程》
  • NFS服务器搭建(案例)
  • ubuntu 22.04 安装 Docker Desktop 及docker介绍
  • 微前端中的应用隔离是什么,一般是怎么实现的?
  • 【python pandas】合并文件并剔除重复数据
  • Spellman高压电源X射线发生器维修XRB160PN480X4593
  • msvcr120.dll丢失怎样修复?msvcr120.dll丢失修复的四个方法
  • 马哈鱼SQLFLow数据流生成介绍