美文网首页
open feign的超时配置及源码跟踪

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

作者: 机灵鬼鬼 | 来源:发表于2021-03-01 18:11 被阅读0次

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.ReflectiveFeignFeignInvocationHandler.invoke(ReflectiveFeign.java:100) at com.sun.proxy.Proxy162.getProductListByIds(Unknown Source)

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

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


image.png

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

feign:
  okhttp:
    enabled: true
  httpclient:
    #关闭默认的httpclient
    enabled: false
    #整个连接池最大连接数
    max-connections: 200
    #每个路由的最大连接,默认50
    max-connections-per-route: 50
  client:
    config:
      default: #使用默认的feignclient时,超时可以生效
        connectTimeout: 111000
        readTimeout: 111000
image.png

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


image.png

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

feign:
   client:
      config:
        default: #这里就是指的所有被加载的默认FeignClient实现的服务配置都生效
            connectTimeout: 111000
            readTimeout: 111000
          

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

相关文章

网友评论

      本文标题:open feign的超时配置及源码跟踪

      本文链接:https://www.haomeiwen.com/subject/ubzbfltx.html