zoukankan      html  css  js  c++  java
  • Feign Client的超时时间

    Spring Cloud微服务架构中,大部分公司都是利用Open Feign进行服务间的调用,而比较简单的业务使用默认配置是不会有多大问题的,但是如果是业务比较复杂,服务要进行比较繁杂的业务计算,那后台很有可能会出现Read Timeout这个异常,因此定制化配置超时时间就有必要了。

    Feign Client Configuration

    # 默认开启
    feign.httpclient.enabled=false
    # 默认关闭
    feign.okhttp.enabled=true
    # 默认关闭
    feign.hystrix.enabled=false
    # 默认关闭
    feign.sentinel.enabled=true
    
    # default context 连接超时时间
    feign.client.config.default.connectTimeout = 5000
    # default context 读超时时间
    feign.client.config.default.readTimeout = 10000
    
    # 设置重试处理器,默认直接抛出异常
    # feign.client.config.default.retryer = Class<Retryer>
    # 设置日志级别,默认NONE
    # feign.client.config.default.loggerLevel = FULL
    

    Hystrix Configuration

    # 全局设置超时:
    hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 30000
    

    hystrix在ribbon的外层处理。

    Ribbon Configuration

    # 连接超时时间,默认为1秒,该值会被FeignClient配置connectTimeout覆盖
    ribbon.ConnectTimeout=5000
    # 读超时时间,默认为1秒,该值会被FeignClient配置readTimeout覆盖
    ribbon.ReadTimeout=5000
    # 最大重试次数
    ribbon.MaxAutoRetries=1
    

    当Ribbon调用接口发送连接异常或者超时异常时会触发Ribbon 的重试机制。

    OkHttp Client Configuration

    所设置的连接时间和超时时间最后会动态设置到OkHttpClient中,最底层也就是Socket的连接时间和读超时时间。也就是说,直接配置OkHttpClient是无效的。

    解决方案:添加OkHttp Client的请求Interceptor,动态设置超时时间。

    @Bean("okHttpClient")
    public OkHttpClient okHttpClient(ConnectionPool connectionPool) {
    	return new OkHttpClient().newBuilder().connectionPool(connectionPool)
                 // 改值在FeignClient体系中会被动态覆盖
    			.connectTimeout(6, TimeUnit.SECONDS)
                 // 改值在FeignClient体系中会被动态覆盖
    			.readTimeout(VmcConstants.TEN_SECONDS, TimeUnit.SECONDS)
                 // 添加拦截器,支持动态设置超时时间
    			.addInterceptor(new OkHttpClientDynamicTimeoutInterceptor())
                .eventListener(eventListener())
    			.build();
    }
    

    总结

    1.如何配置好HystrixRibbon的超时时间呢?

    其实是有套路的,因为Feign的请求:其实是Hystrix+RibbonHystrix在最外层,然后再到Ribbon,最后里面的是http请求。所以说。Hystrix的熔断时间必须大于Ribbon的 ( ConnectTimeout + ReadTimeout )。而如果Ribbon开启了重试机制,还需要乘以对应的重试次数,保证在Ribbon里的请求还没结束时,Hystrix的熔断时间不会超时。

    参考资料

    【1】Spring Cloud Openfeign

    【2】Feign的各种超时时间

  • 相关阅读:
    窗体句柄总是0
    该函数设置由不同线程产生的窗口的显示状态。
    zip压缩解压缩 项目icsharpcode-SharpZipLib-e012155
    VS(Microsoft Visual Studio2010)工具打开项目所需的应用程序,出现未安装(.csproj)的应用程序的解决办法
    Cocoa深入学习:NSOperationQueue、NSRunLoop和线程安全
    iPhone 6出现后,如何将一份设计稿支持多个尺寸?
    iPhone/Mac Objective-C内存管理教程和原理剖析
    What does the “__block” keyword mean?
    UIView frame, bounds and center
    ARC __bridge modifiers demystified
  • 原文地址:https://www.cnblogs.com/kancy/p/13033021.html
Copyright © 2011-2022 走看看