zoukankan      html  css  js  c++  java
  • SpringCloud openFeign远程调用超时解决办法

    问题

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

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

    原因

    OpenFeign 内部集成了HytrixRibbon 组件,当设置了

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

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


    补充: 在引入了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. Ribbon的超时有2个:连接超时和处理超时,默认都是1秒。

    2. Ribbon的默认重试也有2个:同一实例的重试次数和负载均衡的不同实例的重试次数,默认为1次和0次。

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

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

    结论:配置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
    

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

  • 相关阅读:
    configuration details
    Java教程 Java API 模拟器学习
    如何用CSC.exe来编译Visual C#的代码文件
    finally 里不能有return语句
    J2ME(cldc/midp)简介
    eclipse+mysql+tomcat配置JNDI
    JDK+Tomcat+Servlet连接Mysql数据库
    访问 IIS 元数据库失败
    硬盘安装Ubuntu
    tomcat与IIS服务器集成
  • 原文地址:https://www.cnblogs.com/hnxbp/p/14963221.html
Copyright © 2011-2022 走看看