咨询个技术问题,feign 调用 spring cloud gateway ,feign 设置了 readtimeout 和 retry ,gateway 设置了 response timeout 和 retry filter ,哪个会生效?
另外在 feign 调用 gateway spring cloud 的场景下, 如何做到每个接口自定义 timeout 和 retry
1
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 就可以了。之前我配过这些,没什么难度,就是查文档搜资料费时间,希望我的回复可以减少你找各种配置的时间。 |
2
notwaste 2023-10-14 22:29:56 +08:00
feign 调用应该不经过网关
|
3
jeffreyji666 OP @mmdsun 我们是通过 feign 来发请求到 spring cloud gateway ,由 gateway route 请求到相关的服务,现在的问题是如何组合 feign 和 spring cloud gateway 的 timeout ,retry 设置来起到效果
|
4
cp19890714 2023-10-14 23:42:26 +08:00
这个 gateway 是你们组的,还是其他组的?
如果是你们组的,为什么要经过自己的 gateway ,带来了什么好处? |
5
jeffreyji666 OP 可以理解成其他组的,难点在于如何组合 feign 和 spring cloud gateway 的 timeout 和 retry 机制
|
6
totoro52 2023-10-15 15:07:49 +08:00
你们这也太混乱了, 其他组不应该也是属于同一个服务体系内的吗
|