一、概述
Gateway是Spring Cloud中的一部分,提供了一種靈活的、可擴展的方式來構建API網關,是整個微服務架構的入口和出口。Gateway過濾器位於Gateway請求處理流程的關鍵位置,可以對請求進行預處理或後處理。
Gateway默認提供了一些常用的過濾器,如路由、重試等,同時也可以自定義過濾器。本文將從過濾器的類型、實現方式、應用場景等方面對Gateway過濾器進行詳解。
二、Gateway過濾器類型
Gateway過濾器根據實現方式可以分為Global Filter和Scoped Filter兩種類型。
1. Global Filter
Global Filter是在整個Gateway路由請求流程中都會執行的過濾器,可以實現一些全局的功能,如請求鑒權、請求日誌等。
Global Filter的實現方式很簡單,只需要實現GatewayFilter接口並將其註冊到RouteLocator中即可:
public class AuthFilter implements GatewayFilter {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
// 鑒權邏輯
return chain.filter(exchange);
}
}
@Configuration
public class GatewayConfig {
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes()
.route("auth_route", r -> r.path("/api/**").filters(f -> f.filter(new AuthFilter()))
.uri("lb://auth-service"))
.build();
}
}
2. Scoped Filter
Scoped Filter是在指定路由規則下執行的過濾器,可以實現路由相關的功能,如路由重試、請求頭修改等。
Scoped Filter的實現方式也很簡單,只需要在RouteDefinition中將其註冊即可:
@Configuration
public class GatewayConfig {
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes()
.route("retry_route", r -> r.path("/api/**").filters(f -> f.rewritePath("/api/(?<name>.*)", "/${name}")
.addRequestHeader("X-Request-ID", UUID.randomUUID().toString())
.retry(3))
.uri("lb://service"))
.build();
}
}
三、Gateway過濾器實現
Gateway過濾器需要實現GatewayFilter接口,並在filter方法中編寫自定義的過濾邏輯。需要注意的是,filter方法返回的是Mono<Void>類型,表示過濾完成後需要繼續調用下一個過濾器。
過濾器可以獲取到ServerWebExchange對象,可以通過該對象對請求或響應進行修改或獲取各種必要信息。
以下是一個自定義的限流過濾器實現:
public class RateLimiterFilter implements GatewayFilter {
private final RateLimiter rateLimiter;
public RateLimiterFilter(RateLimiter rateLimiter) {
this.rateLimiter = rateLimiter;
}
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
Mono<Boolean> isAllowed = rateLimiter.isAllowed(exchange.getRequest().getRemoteAddress().getAddress());
return isAllowed.flatMap(allowed -> {
if (allowed) {
return chain.filter(exchange);
} else {
exchange.getResponse().setStatusCode(HttpStatus.TOO_MANY_REQUESTS);
return exchange.getResponse().setComplete();
}
});
}
}
@Configuration
public class GatewayConfig {
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder,
RateLimiter rateLimiter) {
return builder.routes()
.route("rate_limit_route", r -> r.path("/api/**").filters(f -> f.filter(new RateLimiterFilter(rateLimiter)))
.uri("lb://service"))
.build();
}
}
四、Gateway過濾器應用場景
Gateway過濾器的應用場景非常廣泛,可以通過過濾器實現各種功能,以下是一部分常見場景:
1. 請求鑒權
通過過濾器對請求進行鑒權,如校驗請求頭、Token等。
2. 請求日誌
通過過濾器實現請求日誌記錄,方便問題排查和性能優化。
3. 限流
通過過濾器實現請求的限流功能,避免被惡意攻擊或高並發請求拖垮服務。
4. 敏感信息過濾
通過過濾器實現敏感信息的過濾,如過濾手機號、銀行卡號等。
5. 請求重試
通過過濾器實現請求的重試功能,避免因為下游服務不可用而導致的請求失敗。
五、總結
Gateway過濾器是Spring Cloud Gateway中非常重要的一部分,可以對請求進行預處理或後處理,實現各種功能。本文從過濾器類型、實現方式、應用場景等方面對Gateway過濾器進行了詳細的介紹,並提供了相關的代碼示例。
原創文章,作者:XTLDZ,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/368218.html
微信掃一掃
支付寶掃一掃