V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
jeffreyji666
V2EX  ›  Java

feign 和 spring cloud gateway 的 timeout 和 retry 设置

  •  
  •   jeffreyji666 · 195 天前 via Android · 935 次点击
    这是一个创建于 195 天前的主题,其中的信息可能已经有所发展或是发生改变。

    咨询个技术问题,feign 调用 spring cloud gateway ,feign 设置了 readtimeout 和 retry ,gateway 设置了 response timeout 和 retry filter ,哪个会生效?

    另外在 feign 调用 gateway spring cloud 的场景下, 如何做到每个接口自定义 timeout 和 retry

    6 条回复    2023-10-15 15:07:49 +08:00
    mmdsun
        1
    mmdsun  
       195 天前
    feign 调用 gateway 应用网关是个什么意思??
    feign 作为 http 客户端,不是应该通过 LoadBalancer 、Ribbon 等调用其他微服务么?

    配置 feign 很简单。
    feign.client.config.ClientName.connectTimeout=3000
    feign.client.config.ClientName.readTimeout=3000
    更多配置参考:
    https://docs.spring.io/spring-cloud-openfeign/docs/current/reference/html/#spring-cloud-feign-overriding-defaults
    如果你启用了 feign 的断路器( spring circuitbreaker resilience4j 、Hystrix )你还要配置对应断路器的超时时间。断路器可以精确到 feign 每个方法的超时时间有个 NameResolver 可以关联 feign 每个方法。


    spring gateway 代理微服务一般都启用了断路器,你要配置断路器,然后把断路器名字加到 gateway 的 router 下。
    https://cloud.spring.io/spring-cloud-circuitbreaker/reference/html/index.html
    当然也可以自定义 metadata 简化配置参考:
    https://stackoverflow.com/questions/63300986/how-to-set-a-time-out-in-spring-cloud-gateway
    gateway 配置到方法级别,你就多配几个 router ,分别指定不同的超时时间的 CircuitBreaker 就可以了。之前我配过这些,没什么难度,就是查文档搜资料费时间,希望我的回复可以减少你找各种配置的时间。
    notwaste
        2
    notwaste  
       195 天前
    feign 调用应该不经过网关
    jeffreyji666
        3
    jeffreyji666  
    OP
       195 天前 via Android
    @mmdsun 我们是通过 feign 来发请求到 spring cloud gateway ,由 gateway route 请求到相关的服务,现在的问题是如何组合 feign 和 spring cloud gateway 的 timeout ,retry 设置来起到效果
    cp19890714
        4
    cp19890714  
       195 天前
    这个 gateway 是你们组的,还是其他组的?
    如果是你们组的,为什么要经过自己的 gateway ,带来了什么好处?
    jeffreyji666
        5
    jeffreyji666  
    OP
       195 天前 via Android
    可以理解成其他组的,难点在于如何组合 feign 和 spring cloud gateway 的 timeout 和 retry 机制
    totoro52
        6
    totoro52  
       195 天前
    你们这也太混乱了, 其他组不应该也是属于同一个服务体系内的吗
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2832 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 164ms · UTC 10:01 · PVG 18:01 · LAX 03:01 · JFK 06:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.