feign 和 spring cloud gateway 的 timeout 和 retry 设置

2023-10-14 19:49:36 +08:00
 jeffreyji666

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

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

1148 次点击
所在节点    Java
6 条回复
mmdsun
2023-10-14 21:57:54 +08:00
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
2023-10-14 22:29:56 +08:00
feign 调用应该不经过网关
jeffreyji666
2023-10-14 22:31:27 +08:00
@mmdsun 我们是通过 feign 来发请求到 spring cloud gateway ,由 gateway route 请求到相关的服务,现在的问题是如何组合 feign 和 spring cloud gateway 的 timeout ,retry 设置来起到效果
cp19890714
2023-10-14 23:42:26 +08:00
这个 gateway 是你们组的,还是其他组的?
如果是你们组的,为什么要经过自己的 gateway ,带来了什么好处?
jeffreyji666
2023-10-14 23:57:10 +08:00
可以理解成其他组的,难点在于如何组合 feign 和 spring cloud gateway 的 timeout 和 retry 机制
totoro52
2023-10-15 15:07:49 +08:00
你们这也太混乱了, 其他组不应该也是属于同一个服务体系内的吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/982004

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX