本文探讨了在使用Spring Cloud OpenFeign进行远程调用时可能出现的超时问题,并提供了解决超时问题的方法。通过合理的配置和设置,开发人员可以有效地解决由于网络延迟等原因导致的远程调用超时情况,确保系统的稳定性和可靠性。
Spring Cloud OpenFeign是一种用于简化微服务架构下远程服务调用的框架。然而,在实际使用中,由于网络延迟、服务端响应时间等原因,远程调用可能会出现超时问题,导致系统性能下降甚至崩溃。为了解决这一问题,本文将介绍一些方法来有效地应对Spring Cloud OpenFeign远程调用超时的情况,确保系统的稳定运行。
在使用openFein进行远程调用的时候,调用超时,报错信息如下:
com.netflix.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超时都是用,但是谁小谁生效,默认为true
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000//熔断器的超时时长默认1秒,最常修改的参数
circuitBreaker.requestVolumeThreshold=20 //触发熔断的最小请求次数,默认为20
circuitBreaker.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的注意事项:
也就是说,如果只有一个实例,连接超时重试1次,处理超时也重试1次。即:实际Ribbon的超时时间是 1秒×2+1秒×2=4秒。
结论:配置Hystrix的timeoutInMillisecond要大于Ribbon的 ( ConnectTimeout + ReadTimeout ) × 2。目的就是保证在熔断之前完成远程调用(包括Ribbon的重试时间)。
1. 开启Feign的Hystrix开关
feign:
hystrix:
enabled: true
2. 设置Hystrix超时时长
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 15000
3. 配置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熔断策略
httpclient:
enabled: true
okhttp:
enabled: false
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 15000
ribbon:
ConnectTimeout: 2000
ReadTimeout: 5000
问题解决,远程调用微服务成功。
Spring Cloud OpenFeign作为微服务架构下的远程调用框架,在实际应用中可能会面临远程调用超时的问题。为了应对这一问题,本文介绍了设置超时时间、使用熔断机制和优化网络通信等方法。通过合理的配置和技术手段,可以有效地解决远程调用超时问题,提升系统的可靠性和性能。