HTTP调用(二):feign调用的超时

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HTTP调用(二):feign调用的超时相关的知识,希望对你有一定的参考价值。

参考技术A

feign客户端默认2个超时时间是1s

如果要配置 Feign 的读取超时,就必须同时配置连接超时,connectTimeout和readTimeout 同时 配置才能生效。

对单独的 Feign Client 设置超时时间,可以把 default 替换为 Client 的 name:

单独的超时可以覆盖全局超时,这符合预期,不算坑

除了可以配置 Feign,也可以配置 Ribbon 组件的参数来修改两个超时时间。
坑点4是,参数首字母要大写,和 Feign 的配置不同。

结论:同时配置 Feign 和 Ribbon 的超时,以 Feign 为准

open feign的超时配置及源码跟踪

参考技术A content:[2021-02-26 18:43:59.939][http-nio-8080-exec-11][ERROR][c.l.c.c.r.RestCartServiceImpl:50] [reqId:7C0AB48A63C843C99CE5BC6A4ED85244] <getMyCartDetail> 操作异常: feign.RetryableException: Read timed out executing POST http://cic-product-service/cic-product/getProductListByIds at feign.FeignException.errorExecuting(FeignException.java:249) at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:129) at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:89) at feign.ReflectiveFeign Proxy162.getProductListByIds(Unknown Source)

问题:在application.yaml中配置的feign的超时一直不生效,在网上也找不到相应的合理解决方案,通常的答案是对feign依赖的底层ribbon设置超时来解决,但这个不是官方推荐的方式,所以我就产生了跟踪源码的兴趣。

解决方案:首先我是通过对@FeignClient注解源码进行了断点跟踪,看下在服务启动时,spring boot是如何加载OpenFeign的超时配置的,最后跟踪到

FeignClientFactoryBean的configureUsingProperties方法读取了feign的配置

跟踪到这儿,就可以知道在我们对@FeignClient不进行重写或者不额外指定configuration的配置时,他是默认加载default配置,而这个default配置默认超时是2秒

要想更改这个默认超时时间需要按照官方推荐的格式,才能生效,如下:

按照配置设置后,又对该服务配置做了验证和压测,在4核8g的mac本上,查询购物车服务支持150个并发,异常率0%,比之前的70%异常率,大大降低,至此完美解决线上问题。

以上是关于HTTP调用(二):feign调用的超时的主要内容,如果未能解决你的问题,请参考以下文章

feign调用超时

Feign调用时读取超时(Read timed out executing GET)解决方法

微服务调用时的超时异常,使用feign的时候负载均衡策略的调整

open feign的超时配置及源码跟踪

Spring Cloud Alibaba - 14 OpenFeign自定义配置 + 调用优化 + 超时时间

Ribbon超时设置