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的错误嘛

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值