gpt4 book ai didi

基于FeignClient调用超时的处理方案

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章基于FeignClient调用超时的处理方案由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

FeignClient调用超时

出现问题的前提

SpringCloud间FeignClient调用出现ReadTimeOut的情况 。

FeignClient服务间调用的默认超时时间为2秒 。

网上查找的解决方案 。

关闭Hystrix(馊主意) 。

延长超时间(Spring众多超时时间配置繁多) 。

解决方案

为FeignClient添加自定义的超时配置,结合Nacos可控 。

话不多说,贴出源码 。

  1. /**
  2. * FeignClient配置类
  3. *
  4. * @author gralves
  5. * @date 2020/8/10
  6. */
  7. @Component
  8. public class FeignClientConfig {
  9. // 连接超时
  10. @Value("${service.feign.connectTimeout:60000}")
  11. private int connectTimeout;
  12.  
  13. // 数据读取超时
  14. @Value("${service.feign.readTimeOut:60000}")
  15. private int readTimeout;
  16. // 构造自定义配置类
  17. @Bean
  18. public Request.Options options() {
  19. return new Request.Options(connectTimeout, readTimeout);
  20. }
  21. }

FeignClient使用自定义配置类 。

  1. // configuration字段使用自定义配置
  2. @FeignClient(value = "xxx", configuration = FeignClientConfig.class)
  3. public interface XxxFeignClient {...

启动服务A/B,进行服务调用,断点59秒(不超时),断点60秒(ReadTimeOut).可以发现配置是生效的 。

建议

不同的服务可以配置不同的超时时间 。

FeignClient可以抽成公共工具包进行使用 。

缺点

太麻烦,觉得调试配置麻烦的可以使用~ 。

FeignClient超时配置

Feign 其实是一种包装,把复杂的 Http 请求包装成我们只需写一两个注解就可以搞定的地步。他底层使用的还是 Ribbon.

Feign 的调用,总共分为两层,即 Ribbon 的调用和 Hystrix(熔断处理) 的调用,高版本的 Hystrix 默认是关闭的.

Ribbon 超时配置

基于FeignClient调用超时的处理方案

如果出现上图的信息,说明是 Ribbon 超时了,需要在配置文件中进行控制处理:

  1. ### Ribbon 配置
  2. ribbon:
  3. # 连接超时
  4. ConnectTimeout: 2000
  5. # 响应超时
  6. ReadTimeout: 5000

Hystrix 超时配置

开启 Hystrix 。

  1. ### Feign 配置
  2. feign:
  3. # 开启断路器(熔断器)
  4. hystrix:
  5. enabled: true

此时,如果超时,汇报一下错误:

基于FeignClient调用超时的处理方案

默认 Hystrix 超时配置:

基于FeignClient调用超时的处理方案

为了避免超时,我们可以根据业务情况来配置自己的超时时间,此处配置熔断时间为:5000/毫秒。注意:建议 Ribbon 的超时时间不要大于 Hystrix 的超时时间 。

  1. ### Hystrix 配置
  2. hystrix:
  3. # 这样将会自动配置一个 Hystrix 并发策略插件的 hook,这个 hook 会将 SecurityContext 从主线程传输到 Hystrix 的命令。
  4. # 因为 Hystrix 不允许注册多个 Hystrix 策略,所以可以声明 HystrixConcurrencyStrategy
  5. # 为一个 Spring bean 来实现扩展。Spring Cloud 会在 Spring 的上下文中查找你的实现,并将其包装在自己的插件中。
  6. shareSecurityContext: true
  7. command:
  8. default:
  9. circuitBreaker:
  10. # 当在配置时间窗口内达到此数量的失败后,进行短路。默认20个
  11. requestVolumeThreshold: 1
  12. # 触发短路的时间值,当该值设为5000时,则当触发 circuit break 后的5000毫秒内都会拒绝request
  13. # 也就是5000毫秒后才会关闭circuit。默认5000
  14. sleepWindowInMilliseconds: 15000
  15. # 强制打开熔断器,如果打开这个开关,那么拒绝所有request,默认false
  16. forceOpen: false
  17. # 强制关闭熔断器 如果这个开关打开,circuit将一直关闭且忽略,默认false
  18. forceClosed: false
  19. execution:
  20. isolation:
  21. thread:
  22. # 熔断器超时时间,默认:1000/毫秒
  23. timeoutInMilliseconds: 5000

源码:https://github.com/SlowSlicing/demo-spring-cloud-finchley/tree/FeignClientTimeoutConfiguration 。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们.

原文链接:https://blog.csdn.net/weixin_43273174/article/details/107918585 。

最后此篇关于基于FeignClient调用超时的处理方案的文章就讲到这里了,如果你想了解更多关于基于FeignClient调用超时的处理方案的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com