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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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%异常率,大大降低,至此完美解决线上问题。

以上是关于open feign的超时配置及源码跟踪的主要内容,如果未能解决你的问题,请参考以下文章

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

Feign Client超时时间配置以及单独给某接口设置超时时间方法记录

深入理解feignribbon和hystrix三者的关系及超时配置[转]

feign服务间调用超时时间

SpringCloudAlibaba微服务组件Feign

SpringCloudAlibaba微服务组件Feign