文章插图
环境:Spring Cloud Gateway 3.1.4
路由元信息配置你可以使用元数据为每个路由配置其他参数 , 如下所示:
spring:cloud:gateway:routes:- id: route_with_metadatauri: https://pack.commetadata:zone: "xj"infos:name: "value"weight: 0.2
可以通过ServerWebExchange中获取所有元数据属性 , 如下所示:// 获取路由对象Route route = exchange.getAttribute(GATEWAY_ROUTE_ATTR);// 获取路由元信息route.getMetadata();// 获取某一个元信息route.getMetadata(someKey);
上面exchange.getAttribute方法获取路由对象是在通过HandlerMApping对象查找路由对象时设置到当前的上下文中的 , 如下:public class RoutePredicateHandlerMapping extends AbstractHandlerMapping {private final FilteringWebHandler webHandler;public RoutePredicateHandlerMapping(FilteringWebHandler webHandler, ...) {this.webHandler = webHandler;// ...}protected Mono<?> getHandlerInternal(ServerWebExchange exchange) {// 查找路由return lookupRoute(exchange).flatMap((Function<Route, Mono<?>>) r -> {exchange.getAttributes().remove(GATEWAY_PREDICATE_ROUTE_ATTR);// 将查找到的路由保存到当前的执行上下文中exchange.getAttributes().put(GATEWAY_ROUTE_ATTR, r);return Mono.just(webHandler);}).switchIfEmpty(Mono.empty().then(Mono.fromRunnable(() -> {exchange.getAttributes().remove(GATEWAY_PREDICATE_ROUTE_ATTR);})));}}
路由的超时配置就是通过元信息的配置来设置的 , 接下来就是路由超时相关的讲解 。路由(http)超时配置Http超时(响应和连接)可以为所有路由配置 , 并为还可以为每个特定路由覆盖 。
- 全局超时配置
连接超时必须以毫秒为单位指定 。
响应超时必须指定为JAVA.time.Duration
spring:cloud:gateway:httpclient:connect-timeout: 1000response-timeout: 5s
- 每个路由配置超时
连接超时必须以毫秒为单位指定 。
响应超时必须以毫秒为单位指定 。
- id: per_route_timeoutsuri: https://example.orgpredicates:- name: Pathargs:pattern: /delay/{timeout}metadata:response-timeout: 200connect-timeout: 200
使用Java DSL的每个路由超时配置:import static org.springframework.cloud.gateway.support.RouteMetadataUtils.CONNECT_TIMEOUT_ATTR;import static org.springframework.cloud.gateway.support.RouteMetadataUtils.RESPONSE_TIMEOUT_ATTR;@Beanpublic RouteLocator customRouteLocator(RouteLocatorBuilder routeBuilder){return routeBuilder.routes().route("test1", r -> {return r.host("*.somehost.org").and().path("/somepath").filters(f -> f.addRequestHeader("header1", "header-value-1")).uri("http://someuri").metadata(RESPONSE_TIMEOUT_ATTR, 200).metadata(CONNECT_TIMEOUT_ATTR, 200);}).build();}
超时时间配置为负值的每条路由响应超时将禁用全局响应超时值 。- id: per_route_timeoutsuri: https://example.orgpredicates:- name: Pathargs:pattern: /delay/{timeout}metadata:response-timeout: -1
流式的Java路由API@Beanpublic RouteLocator customRouteLocator(RouteLocatorBuilder builder, ThrottleGatewayFilterFactory throttle) {return builder.routes().route(r -> r.host("**.abc.org").and().path("/image/png").filters(f -> f.addResponseHeader("X-TestHeader", "foobar")).uri("http://httpbin.org:80")).route(r -> r.path("/image/webp").filters(f -> f.addResponseHeader("X-AnotherHeader", "baz")).uri("http://httpbin.org:80").metadata("key", "value")).route(r -> r.order(-1).host("**.throttle.org").and().path("/get").filters(f -> f.filter(throttle.apply(1,1,10,TimeUnit.SECONDS))).uri("http://httpbin.org:80").metadata("name", "pack")).build();}
这种风格还允许更多的自定义谓词断言 。RouteDefinitionLocator bean定义的谓词使用逻辑和进行组合 。通过使用流畅的Java API , 可以在Predicate类上使用and()、or()和negate()操作符 。- DiscoveryClient路由定义定位器
要启用此功能 , 需要将spring.cloud.gateway.decovery.locator.enabled设置为true , 并确保DiscoveryClient实现(?.NETflix Eureka、Consul、Zookeeper或Nacos)位于类路径上并已启用 。
推荐阅读
- SpringIOC循环依赖问题
- Spring/SpringBoot中的声明式事务和编程式事务源码、区别、优缺点、适用场景、实战
- SpringBoot+Vue+ES 实现仿百度全文搜索
- Spring Statemachine应用实践
- SpringBoot整合RocketMQ,老鸟们都是这么玩的!
- Spring注解@After,@Around,@Before的执行顺序?
- Spring Boot+Nacos+gRPC,一个区别于 OpenFeign 的微服务通信方案!
- 在 SpringBoot 中使用 Spring AOP 实现接口鉴权
- SpringBoot中如何实现限流,这种方式才叫优雅!
- SpringBoot中使用PostgreSQL数据库