专栏首页arebirth重生者的IT之路SpringCloud之Feign 负载均衡请求超时时间

SpringCloud之Feign 负载均衡请求超时时间

版本声明:

 SpringCloud:Greenwich.SR4

   SpringBoot:2.1.9.RELEASE


Feign调用服务的默认时长是1秒钟,也就是如果超过1秒没连接上或者超过1秒没响应,那么会相应的报错。

但是在实际的业务中,我们的服务可能因为特别原因(网络、处理压力大等)导致相应速度超过1秒钟,那么就会报错,

下面我们就来处理如何手动配置Feigin的负载均衡超时等参数

全局配置

SpringCloud负载均衡底层用的就是Ribbon

#--------------Feign负载均衡配置 配置全局超时时间
ribbon:
  ConnectTimeout: 5000 #请求连接的超时时间,默认时间为1秒
  ReadTimeout: 5000 #请求处理的超时时间

5秒没有响应成功就报如下错误(真实情况下,会比5s多一些,因为发送请求也需要时间的,模拟超时可以在请求处理的方法上用Thread.sleep()设置休眠时间超过5s)


局部配置(就是指定提供者)

#--------------Feign负载均衡配置 局部配置超时时间等
feign-product-provider: #指定配置的服务名称
  ribbon:
    OkToRetryOnAllOperations: true # 对所有请求都进行重试
    MaxAutoRetries: 2 # 对当前实例的重试次数
    MaxAutoRetriesNextServer: 0 # 切换实例的重试次数(集群状态下,其它对其它实例服务重试的次数)
    ConnectTimeout: 3000 # 请求连接的超时时间
    ReadTimeout: 3000 # 请求处理的超时时间

上述提到的服务名称如下配置

spring:
  application:
    name: feign-product-provider # 随意设置

执行的代码

输出结果


不是一共重试两次吗?这里边就涉及到了一个公式

 共重试次数 = (MaxAutoRetries+MaxAutoRetriesNextServer+(MaxAutoRetries * MaxAutoRetiresNextServer)
      = 2 + 0 + (2 * 0)
      = 2
在加上我们手动请求一次那就是:2 + 1 = 3次



公式很重要!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Spring Cloud(二)《服务提供与负载均衡调用 Eureka》

    本章节提供一个基于Eurka的服务注册中心,两个服务提供者之后分别使用Ribbon、Fegin方式进行调用,测试负载均衡。

    小傅哥
  • Feign讲解与应用(文末送书)

    Feign 的英文表意为“假装,伪装,变形”, 是一个http请求调用的轻量级框架,可以以Java接口注解的方式调用Http请求,而不用像Java中通过封装HT...

    后端码匠
  • feign client设置超时时间

    十毛
  • 微服务Spring Cloud功能介绍

    集群:多台服务器部署相同应用构成一个集群 作用:通过负载均衡设备共同对外提供服务

    chenchenchen
  • Spring全家桶之SpringCloud——高级阶段(上)

    SpringCloud高级阶段上 (当前所在位置) 第一章 负载均衡Ribbon 第二章 声明式调用Feign 第三章 服务容错保护Hystrix

    时间静止不是简史
  • 微服务组件教程^-^带你搞懂OpenFeign

    目前在SpringCloud技术栈中,调用服务用得最多的就是OpenFeign,所以这篇文章讲一下OpenFeign,希望对大家有所帮助。

    java技术爱好者
  • 快速学习-Feign远程调用

    在前后端分离架构中,服务层被拆分成了很多的微服务,服务与服务之间难免发生交互,比如:课程发布需要调用 CMS服务生成课程静态化页面,本节研究微服务远程调用所使用...

    cwl_java
  • Spring Cloud 面试必知必会35个问,你能答上几个?

    Spring Cloud为开发人员提供了工具,以快速构建分布式系统中的一些常见模式(例如,配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全...

    Java小咖秀
  • springcloud微服务实战:Eureka+Zuul+Feign/Ribbon+Hystrix Turbine+SpringConfig+sleuth+zipkin

    用户2235302

扫码关注云+社区

领取腾讯云代金券