hystrix.command feign ribbon 超时问题

application.properties
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=93000
hystrix.command.default.execution.timeout.enabled=true

我的版本是springCloud

Finchley.SR1 至于包有这个就够 
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

在研究代码的过程发现这两个配置点不进去 cant resolve 其他代码都能点进去但是唯独这个点不进去 我还以为我少引包了 然后我自己研究了下 众所周知Feign是包裹了ribbon的来进行访问的 所以这总共有三次超时时间需要考虑的 第一个是feign 总配置

application.yml

#没有默认 不配这个话 就看下面hystrix的时间
feign:
  client:
    config:
      #服务名 默认的话为所有默认加上那个
      default:
        connectTimeout: 5000
        readTimeout: 5000
      client:
        connectTimeout: 5000
        readTimeout: 5000
#这个时间是管用的一旦开启 默认是一秒 和上面那个时间哪个小哪个管用
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 10000

还有 application.properties

#对当前实例的重试次数  
ribbon.MaxAutoRetries=1

ribbon.ConnectTimeout=1000
#对所有操作请求都进行重试 包括请求超时和读取超时 设置为false时 只对get请求进行重试 否则对post put都进行重试
ribbon.OkToRetryOnAllOperations=true
ribbon.ReadTimeout=1000
#切换实例的重试次数
ribbon.MaxAutoRetriesNextServer=1

首先前提是这三个时间谁小 谁管用 我之前一直以为没用 是因为设置得太大  另外feign优先级高于ribbon的优先级 因为

LoadBalancerFeignClient.class
  IClientConfig getClientConfig(Options options, String clientName) { 
        Object requestConfig;
       这句话的意思是如果feign没有配置超时时间的话 就去读取ribbon的配置 也就是ribbon.readTimeout
另外这个默认时间 连接时间是10秒 读取时间60秒
        if (options == DEFAULT_OPTIONS) {
            requestConfig = this.clientFactory.getClientConfig(clientName);
        } else {
            requestConfig = new LoadBalancerFeignClient.FeignOptionsClientConfig(options);
        }

        return (IClientConfig)requestConfig;
    }

另外除了hystrix的超时时间 其他时间都是一个readtimeout 和connectTimeout两部分组成 测试的时候 两个加一下 另外最最重要的一点 测试的时候千万不要把被调用另一方的服务简单停掉 那样其实是在调用一方是报错了的 怪不得 我每次调用都很快 我还以为 Hystrix开启了断路器 其实并没有 通过健康检查可以发现他一直是up  这点他报错就是cant resolve any server 但是就是不打印出来 没办法 跟踪源码才看出来

这个类是执行的最后一部 据我推测  至于被调用一方可以打Debug 制造出来readTimeout的错误嘛

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值