Open Feign 超时 Ribbon 超时 相关内容

冷不防 2022-09-12 15:54 240阅读 0赞

文章目录

  • Open Feign 超时 Ribbon 超时 相关内容
        • 1、默认使用 JDK 自带的 HttpURLConnection ,无连接池,性能、效率低
        • 2、Open Feign 使用 Ribbon 作为负载均衡,他同样默认使用 JDK 自带的 HttpURLConnection
        • 3、全局超时
        • 4、单服务超时
        • 5、熔断超时
        • 6、Ribbon 超时
        • 7、Open Feign 重试机制
        • 8、Ribbon 拉取服务列表
        • 9、Ribbon 重试
        • 10、Hystrix 超时
        • 11、使用 Open Feign 做 http 客户端时

Open Feign 超时 Ribbon 超时 相关内容


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

增加依赖

  1. <dependency>
  2. <groupId>io.github.openfeign</groupId>
  3. <artifactId>feign-httpclient</artifactId>
  4. <version>9.3.1</version>
  5. </dependency>

并设置

  1. feign.httpclient.enabled=true

使用其他组件

增加依赖

  1. <dependency>
  2. <groupId>io.github.openfeign</groupId>
  3. <artifactId>feign-okhttp</artifactId>
  4. <version>10.2.0</version>
  5. </dependency>

并设置

  1. feign.okhttp.enabled=true

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

需要设置

  1. ribbon.okhttp.enabled=true

3、全局超时

需要设置

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

4、单服务超时

给单独的服务设置超时

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

5、熔断超时

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

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

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

6、Ribbon 超时

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

配置 Ribbon 的超时

  1. ribbon.ConnectTimeout=2000
  2. ribbon.ReadTimeout=11000

7、Open Feign 重试机制

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

配置开启重试

  1. @Bean
  2. @ConditionalOnMissingBean
  3. public Retryer feignRetryer() {
  4. return Retryer.NEVER_RETRY;
  5. }
  6. Retryer retryer = new Retryer.Default(100, 1000, 2);

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

8、Ribbon 拉取服务列表

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

  1. 服务名.ribbon.ServerListRefreshInterval=3

9、Ribbon 重试

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

  1. 服务名.ribbon.MaxAutoRetries=1

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

  1. 服务名.ribbon.MaxAutoRetriesNextServer=1

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

  1. 服务名.ribbon.OkToRetryOnAllOperations=false

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

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

10、Hystrix 超时

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

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

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

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

发表评论

表情:
评论列表 (有 0 条评论,240人围观)

还没有评论,来说两句吧...

相关阅读