Open Feign 超时 Ribbon 超时 相关内容

Posted 简简单单OnlineZuozuo

tags:

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

Open Feign 超时 Ribbon 超时 相关内容


1、默认使用 JDK 自带的 HttpURLConnection ,无连接池,性能、效率低

增加依赖

<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
    <version>9.3.1</version>
</dependency>

并设置

feign.httpclient.enabled=true

使用其他组件

增加依赖

<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-okhttp</artifactId>
    <version>10.2.0</version>
</dependency>

并设置

feign.okhttp.enabled=true

2、Open Feign 使用 Ribbon 作为负载均衡,他同样默认使用 JDK 自带的 HttpURLConnection

需要设置

ribbon.okhttp.enabled=true

3、全局超时

需要设置

feign.client.config.default.connectTimeout=2000
feign.client.config.default.readTimeout=60000

4、单服务超时

给单独的服务设置超时

feign.client.config.服务名.connectTimeout=2000
feign.client.config.服务名.readTimeout=60000

5、熔断超时

需要设置开启熔断
feign.hystrix.enabled=true

开启熔断后,可以为单个接口设置超时时间
可以通过 configuration 指定配置类

@FeignClient(value = "service" configuration = FeignMultipartSupportConfig.class)

6、Ribbon 超时

如果没有配置 Feign 超时,但是配置了 Ribbon 的超时,则以 Ribbon 的为准

配置 Ribbon 的超时

ribbon.ConnectTimeout=2000
ribbon.ReadTimeout=11000

7、Open Feign 重试机制

Open Feign 默认不支持重试机制,可以在源代码 FeignClientsConfiguration 中 feignRetryer 中看出

配置开启重试

@Bean
@ConditionalOnMissingBean
public Retryer feignRetryer() {
    return Retryer.NEVER_RETRY;
}

Retryer retryer = new Retryer.Default(100, 1000, 2);

表示每间隔 100ms,最大间隔 1000ms 重试一次,最大重试次数是 1。因为第三个参数包含了第一次请求

8、Ribbon 拉取服务列表

Ribbon 默认从服务端拉取列表的时间间隔是 30s,这个对优雅发布很不友好。一般我们会把这个时间改短,如下改成 3s

服务名.ribbon.ServerListRefreshInterval=3

9、Ribbon 重试

某个实例的最大重试次数,不含首次调用

服务名.ribbon.MaxAutoRetries=1

同一个服务其他实例的最大重试次数,这里不包括第一次调用的实例

服务名.ribbon.MaxAutoRetriesNextServer=1

是否对所有操作都重试,默认 false,建议 false

服务名.ribbon.OkToRetryOnAllOperations=false

对指定的 http 状态码进行重试

服务名.retryableStatusCodes=404,408,502,500

10、Hystrix 超时

Hystrix 默认不开启超时,但是如果开启了 hystrix,因为 hystrix 是在 Ribbon 外面,所以超时时间需要符合下面规则

hystrix超时 >= (MaxAutoRetries + 1) * (ribbon ConnectTimeout + ribbon ReadTimeout)

11、使用 Open Feign 做 http 客户端时

  • 不用配置 ribbon 相关参数
  • 使用 RestTemplate 调用时,不考虑负载均衡
  • 使用过程中 OpenFeign 要组装出自己的一套请求,跟直接使用 http 客户端比,会有一定开销

以上是关于Open Feign 超时 Ribbon 超时 相关内容的主要内容,如果未能解决你的问题,请参考以下文章

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

Ribbon超时设置

springcoud feign超时的问题

feign服务间调用超时时间

Feign请求报请求超时

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