如果想定制DiscoveryClient路由使用的謂詞或過濾器,可以設置spring.cloud.gateway.discovery.locator.predicate[x]和spring.cloud.gateway.discovery.locator.filters[y]。
環(huán)境:Springboot2.4.12 + Spring Cloud Gateway2.2.9.RELEASE
http超時(響應和連接)可以為所有路由配置,并覆蓋每個特定的路由。
全局超時配置
使用實例設置http全局超時。
connect-timeout必須以毫秒為單位指定。
response-timeout必須指定為java.time.Duration
示例:
spring:
cloud:
gateway:
httpclient:
connect-timeout: 2000
response-timeout: 5s
每個路由超時配置
設置路由超時。
connect-timeout必須以毫秒為單位指定。
response-timeout必須以毫秒為單位指定。
spring:
cloud:
gateway:
enabled: true
discovery:
locator:
enabled: true
lowerCaseServiceId: true
default-filters:
- StripPrefix=1
routes:
- id: R003
uri: http://localhost:8082
predicates:
- Path=/api-x/demos/date3
metadata:
#局部超時設置
connect-timeout: 10000
response-timeout: 50000
使用Java DSL配置
import static org.springframework.cloud.gateway.support.RouteMetadataUtils.CONNECT_TIMEOUT_ATTR;
import static org.springframework.cloud.gateway.support.RouteMetadataUtils.RESPONSE_TIMEOUT_ATTR;
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder routeBuilder){
return routeBuilder.routes()
.route("test1", r -> {
return r.host("*.pack.com").and().path("/products")
.filters(f -> f.addRequestHeader("api-key", "abc"))
.uri("http://someuri")
.metadata(RESPONSE_TIMEOUT_ATTR, 2000)
.metadata(CONNECT_TIMEOUT_ATTR, 2000);
}).build();
}
每個路由的response-timeout為負值將禁用全局響應超時值。
- id: per_route_timeouts
uri: https://pack.com
predicates:
- name: Path
args:
pattern: /delay/{timeout}
metadata:
response-timeout: -1
流式路由配置
為了在Java中進行簡單的配置,RouteLocatorBuilder bean包含一個流暢的API。其工作原理如下列代碼清單所示:
@Bean
public 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("key", "value")
)
.build();
}
這種風格還允許更多的自定義謂詞斷言。RouteDefinitionLocator bean定義的謂詞使用logical and進行組合。通過使用流暢的Java API,可以在Predicate類上使用and()、or()和negate()操作符。
DiscoveryClient路由定位
你可以將網(wǎng)關配置為基于在DiscoveryClient兼容服務注冊表中注冊的服務創(chuàng)建路由,直接通過服務名就能訪問。
要啟用此功能,請將spring.cloud.gateway.discovery.locator.enabled設置為true,并確保在類路徑上啟用了DiscoveryClient實現(xiàn)(如Netflix Eureka、Consul、Zookeeper或者Nacos)。
默認情況下,網(wǎng)關為DiscoveryClient創(chuàng)建的路由定義一個謂詞和過濾器。
默認謂詞是用模式/serviceId/**定義的路徑謂詞,其中serviceId是來自DiscoveryClient的服務的ID。
默認過濾器是一個正則表達式/serviceId/?(?<remaining>.*)和替換/${remaining}的重寫路徑過濾器。這將在請求發(fā)送到下游之前從路徑中刪除服務ID。
如果想定制DiscoveryClient路由使用的謂詞或過濾器,可以設置spring.cloud.gateway.discovery.locator.predicate[x]和spring.cloud.gateway.discovery.locator.filters[y]。這樣做時,如果你想保留默認的謂詞和過濾器,就需要確保包含前面展示的默認謂詞和過濾器。如下面的例子所示:
spring.cloud.gateway.discovery.locator.predicates[0].name: Path
spring.cloud.gateway.discovery.locator.predicates[0].args[pattern]: "'/'+serviceId+'/**'"
spring.cloud.gateway.discovery.locator.predicates[1].name: Host
spring.cloud.gateway.discovery.locator.predicates[1].args[pattern]: "'**.foo.com'"
spring.cloud.gateway.discovery.locator.filters[0].name: CircuitBreaker
spring.cloud.gateway.discovery.locator.filters[0].args[name]: serviceId
spring.cloud.gateway.discovery.locator.filters[1].name: RewritePath
spring.cloud.gateway.discovery.locator.filters[1].args[regexp]: "'/' + serviceId + '/?(?<remaining>.*)'"
spring.cloud.gateway.discovery.locator.filters[1].args[replacement]: "'/${remaining}'"
完畢!??!