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 超时 相关内容的主要内容,如果未能解决你的问题,请参考以下文章