栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Open Feign 超时 Ribbon 超时 相关内容

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Open Feign 超时 Ribbon 超时 相关内容

文章目录
  • 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 ,无连接池,性能、效率低

增加依赖


    io.github.openfeign
    feign-httpclient
    9.3.1

并设置

feign.httpclient.enabled=true

使用其他组件

增加依赖


    io.github.openfeign
    feign-okhttp
    10.2.0

并设置

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 客户端比,会有一定开销
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/270510.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号