码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spring Cloud的Feign和ribbon和Hystrix超时时间设置及关系


    目录

    1 Feign超时配置

    1.1 Feign源码默认超时时间

    2 Ribbon超时配置

    2.1 Ribbon源码默认超时时间

    2.2 Feign和Ribbon超时的关系

    3 Hystrix超时配置

    我们用到spring Cloud的时候,Feign和Ribbon和Hystrix都是必不可少的配置项。下面就来详细说下他们三者的关系及如何配置。

    本次演示采用:spring-cloud-starter-openfeign:2.1.0RELEASE版本

    1 Feign超时配置

    #feign超时配置
    feign:
      client:
        config:
          # default 默认是全局超时时间,指定服务名称可以设置单个服务的超时时间
          default:
            # 建立链接所用的时间(连接超时时间:ms)
            connectTimeout: 2000
            # 建立链接后服务器读取资源所用的时间(读取超时时间:ms)
            readTimeout: 5000

     

    1.1 Feign源码默认超时时间

    源码中建立连接所用时间是10 000ms, 读取时间为60 000ms

    我们来跟下源码看一下:

    在启动类中找到该注解

     

    2 Ribbon超时配置

    ribbon:
      # 建立链接所用的时间(连接超时时间:ms)
      connectTimeout: 5000
      # 建立链接后服务器读取资源所用的时间(读取超时时间:ms)
      readTimeout: 5000
      # ribbon刷新时间
      ServerListRefreshInterval: 5000
      # 对当前实例的重试次数
      MaxAutoRetries: 0
      # 对下个实例(切换实例)的重试次数
      MaxAutoRetriesNextServer: 0

      # 是否所有操作都进行重试

      OkToRetryOnAllOperations: false

    对于有些开发场景需要关闭ribbon重试机制,防止发送多次相同的请求

    # 关闭重试机制(可以避免重复修改和插入数据)
    spring.cloud.loadbalancer.retry.enabled=false

    2.1 Ribbon源码默认超时时间

    源码在这个类中:RibbonClientConfiguration(就不截图跟进了)

    源码中建立连接所用时间是1 000ms, 读取时间为1 000ms

    2.2 Feign和Ribbon超时的关系

    Feign 和 Ribbon 的超时时间只有一个生效,规则:如果没有设置过 feign 超时,也就是等于默认值的时候,就会读取 ribbon 的配置,使用 ribbon 的超时时间和重试设置。否则使用 feign 自身的设置。两者是二选一,且 feign 优先。

    3 Hystrix超时配置

    # 设置 hystrix 超时时间(默认是关闭熔断器)
    feign:
      hystrix:
        enabled: true
    hystrix:
      command:
        default:
          execution:
            isolation:
              thread:
                # 熔断时间
                timeoutInMilliseconds: 20000

    hystrix 的默认超时时间是 1s

    如果请求的时间超出了 ribbon(Feign) 的超时限制,或者 hystrix 的超时限制,就会熔断。
    一般来说,会设置 ribbon(Feign)的超时时间 <= hystrix超时时间, 这是为了保证在正常返回结果之前不会发送熔断。

  • 相关阅读:
    1.2 redis7.0.4安装与配置开机自启动
    用HttpURLConnection来实现retrofit类似功能(由于retrofit不支持5.0以下)
    上海亚商投顾:沪指低开低走 抖音概念股逆势爆发
    将“万词王”离线转化为“文络之心“插件之一:复现 wantwords Python/Pytorch 开源项目
    规划类3d全景线上云展馆帮助企业轻松拓展海外市场
    ElementUI中Tree组件使用
    FastDFS(分布式文件系统)使用介绍
    SQLServer添加Oracle链接服务器
    中端酒店迈入“30+”,维也纳酒店如何化解行业的三大难关
    打印水仙花数---c语言刷题
  • 原文地址:https://blog.csdn.net/m0_57640408/article/details/126687298
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号