Feign客户端 - 超时时间配置

Spring Cloud中Feign客户端是默认开启支持Ribbon的,最重要的两个超时就是连接超时ConnectTimeout读超时ReadTimeout,在默认情况下,也就是没有任何配置下,Feign的超时时间会被Ribbon覆盖,两个超时时间都是1秒。

这边简单说一个场景,就不上代码了,app-user服务调用app-order服务中的接口, 然后在app-order的接口中设置1.5s的延迟,看看调用效果:

Feign客户端 - 超时时间配置_第1张图片

Feign客户端 - 超时时间配置_第2张图片

调用出错了,控制台显示读取超时,这就是因为Ribbon默认超时时间为1s导致的。这个只要我们配置一下超时时间就行了:

Ribbon全局配置

在调用方的yml配置文件中添加配置,设置超时时间为5s:

ribbon:
  #建立连接超时时间
  ConnectTimeout: 5000
  #建立连接之后,读取响应资源超时时间
  ReadTimeout: 5000

 然后重启服务,调用成功

Feign客户端 - 超时时间配置_第3张图片

 Feign配置

注: Feign配置会优先于Ribbon配置。配置完之后也是同样的效果。

feign:
  client:
    config:
      #这里填具体的服务名称(也可以填default,表示对所有服务生效)
      app-order:
        #connectTimeout和readTimeout这两个得一起配置才会生效
        connectTimeout: 5000
        readTimeout: 5000

你可能感兴趣的:(Spring,Cloud,spring,cloud,java,后端)