SpringCloud openFeign远程调用超时解决办法

网友投稿 1133 2022-10-04

SpringCloud openFeign远程调用超时解决办法

SpringCloud openFeign远程调用超时解决办法

SpringCloud openFeign远程调用超时解决办法

问题

在使用openFein进行远程调用的时候,调用超时,报错信息如下:

com-flix.hystrix.exception.HystrixRuntimeException: XXXService#login(RequestObject) timed-out and no fallback available.

原因

OpenFeign 内部集成了​​Hytrix​​​ 和 ​​Ribbon​​ 组件,当设置了

feign: hystrix: # 启用fegin断路器 enabled: true

,相当于启用了断路器,那么调用的超时时间将会按照 ​​Ribbon​​​ 和 ​​Hytrix​​ 的较小者去配置。

补充: 在引入了​​openFein​​组件后,可以配置的内容如下所示:

1. hystrix可配置的部分:hystrix.command.default.execution.timeout.enable=true //为false则超时控制有ribbon控制,为true则hystrix超时和ribbon超时都是用,但是谁小谁生效,默认为truehystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000//熔断器的超时时长默认1秒,最常修改的参数circuitBreaker.requestVolumeThreshold=20 //触发熔断的最小请求次数,默认为20circuitBreaker.sleepWindowInMilliseconds=5000 //休眠时长,默认为5秒circuitBreaker.errorThresholdPercentage=50 //触发熔断的失败请求最小占比,默认50%2. ribbon可配置的部分:ribbon.ReadTimeout=1000 //处理请求的超时时间,默认为1秒ribbon.ConnectTimeout=1000 //连接建立的超时时长,默认1秒ribbon.MaxAutoRetries=1 //同一台实例的最大重试次数,但是不包括首次调用,默认为1次ribbon.MaxAutoRetriesNextServer=0 //重试负载均衡其他实例的最大重试次数,不包括首次调用,默认为0次ribbon.OkToRetryOnAllOperations=false //是否对所有操作都重试,默认false 3. Feign可配置的部分:feign.hystrix.enable=false //feign是否启用断路器,默认为false

Ribbon的注意事项:

Ribbon的超时有2个:连接超时和处理超时,默认都是1秒。Ribbon的默认重试也有2个:同一实例的重试次数和负载均衡的不同实例的重试次数,默认为1次和0次。

也就是说,如果只有一个实例,连接超时重试1次,处理超时也重试1次。即:实际Ribbon的超时时间是 1秒×2+1秒×2=4秒。

Ribbon默认GET请求不论是连接失败还是处理失败都会重试,而对于非GET请求只对连接失败进行重试。

结论:配置Hystrix的timeoutInMillisecond要大于Ribbon的 ( ConnectTimeout + ReadTimeout ) × 2。目的就是保证在熔断之前完成远程调用(包括Ribbon的重试时间)。

配置步骤配置步骤:

1. 开启Feign的Hystrix开关feign: hystrix: enabled: true2. 设置Hystrix超时时长hystrix: command: default: execution: isolation: thread: timeoutInMilliseconds: 150003. 配置ribbon的连接时长和服务响应时长ribbon: ConnectTimeout: 2000 ReadTimeout: 5000

解决

版本说明:SpringBoot:2.3.3.Release, OpenFeign: 2.2.7.Release 配置以下​​​Feign​​的配置:

feign: hystrix: # 启用fegin断路器 enabled: true strategy: custom: true # 自定义feign熔断策略 enabled: true ok enabled: falsehystrix: command: default: execution: isolation: thread: timeoutInMilliseconds: 15000ribbon: ConnectTimeout: 2000 ReadTimeout: 5000

问题解决,远程调用微服务成功。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序实例代码:上拉加载更多的实现方法(小程序下拉加载更多)
下一篇:微信小程序中数据绑定的实例分析(代码)(微信小程序数据绑定的数据传递方向是)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~