环球即时:Spring Cloud Gateway过滤器的执行顺序
在Spring Cloud Gateway中,过滤器的执行顺序对于实现请求处理流程的正确性和效率至关重要。Spring Cloud Gateway中的过滤器分为全局过滤器和局部过滤器两种类型,不同类型的过滤器在执行顺序上有所不同。
全局过滤器执行顺序
(资料图片仅供参考)
全局过滤器是指在所有路由规则中都会执行的过滤器,可以用于实现一些全局性的功能,如请求的日志记录、响应头信息的设置等。Spring Cloud Gateway提供了一些内置的全局过滤器,如请求路径的重写、请求日志的记录等。在Spring Cloud Gateway中,全局过滤器的执行顺序是由GatewayFilterAdapter的ORDER常量值确定的,该常量值为-2147483648,表示全局过滤器将在所有的局部过滤器之前执行。
局部过滤器执行顺序
局部过滤器是指只在特定路由规则中才会执行的过滤器,可以用于实现一些特定的功能,如请求鉴权、请求转发等。Spring Cloud Gateway中的局部过滤器可以通过自定义过滤器工厂类来实现,该工厂类需要继承AbstractGatewayFilterFactory抽象类,并实现其中的apply方法和泛型参数指定配置类。在Spring Cloud Gateway中,局部过滤器的执行顺序是由配置文件中的filters属性确定的,该属性可以通过spring.cloud.gateway.routes.filters参数进行配置,不同的过滤器在列表中的位置就决定了它们的执行顺序。
以下是一个示例,其中定义了一个全局过滤器和两个局部过滤器,演示了不同类型过滤器的执行顺序:
@Componentpublic class GlobalFilter implements GatewayFilter, Ordered { @Override public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) { System.out.println("GlobalFilter before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("GlobalFilter after..."); })); } @Override public int getOrder() { return -1; }}@Componentpublic class LocalFilter1 extends AbstractGatewayFilterFactory { public LocalFilter1() { super(Config.class); } @Override public GatewayFilter apply(Config config) { return (exchange, chain) -> { System.out.println("LocalFilter1 before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("LocalFilter1 after..."); })); }; } public static class Config { // 配置参数 }}@Componentpublic class LocalFilter2 extends AbstractGatewayFilterFactory { public LocalFilter2() { super(Config.class); } @Override public GatewayFilter apply(Config config) { return (exchange, chain) -> { System.out.println("LocalFilter2 before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("LocalFilter2 after..."); })); }; } public static class Config { // 配置参数 }}
在这个示例中,我们定义了一个全局过滤器GlobalFilter和两个局部过滤器LocalFilter1和LocalFilter2。其中,GlobalFilter实现了GatewayFilter和Ordered接口,用于实现全局过滤器的逻辑。LocalFilter1和LocalFilter2都继承了AbstractGatewayFilterFactory抽象类,并通过实现apply方法实现了局部过滤器的逻辑。在apply方法中,我们可以实现自己的过滤逻辑,并返回一个GatewayFilter对象。在GatewayFilter对象中,我们可以继续调用chain.filter方法来执行下一个过滤器,或者直接返回结果。这里我们使用Mono.fromRunnable方法来在请求结束时输出一些信息。
在上述示例中,我们定义了全局过滤器和两个局部过滤器。在执行顺序方面,由于全局过滤器的ORDER常量值最小,因此它会在所有的局部过滤器之前执行。而在局部过滤器的执行顺序方面,它们的执行顺序是由配置文件中的filters属性决定的,如下所示:
spring: cloud: gateway: routes: - id: example uri: http://example.org predicates: - Path=/example/** filters: - LocalFilter2 - LocalFilter1
在这个配置文件中,我们为example路由规则指定了两个局部过滤器,分别是LocalFilter2和LocalFilter1。在执行顺序方面,LocalFilter2将会先于LocalFilter1执行,因为它们在filters列表中的位置是从前往后的。也就是说,请求先经过LocalFilter2,再经过LocalFilter1,最后再到达后端服务。
需要注意的是,在GatewayFilterChain中的filter方法调用中,如果其中一个过滤器返回了错误,那么整个请求处理过程会立即停止并返回错误。因此,在设计过滤器时需要格外小心,确保每个过滤器都不会抛出异常,以免影响整个系统的稳定性。
此外,还有一些其他的过滤器类型,如:
Pre Filter:在请求被路由之前调用。可以用来实现身份认证、IP过滤等逻辑。Post Filter:在请求被路由之后调用。可以用来实现响应头处理、日志记录等逻辑。Error Filter:在请求处理过程中发生错误时调用。可以用来实现异常处理、错误日志记录等逻辑。这些过滤器类型可以通过实现不同的接口来实现。例如,实现Ordered和GatewayFilter接口的就是Pre Filter和Global Filter类型的过滤器。而实现Ordered和WebFilter接口的则是Error Filter类型的过滤器。
相关阅读
精彩推荐
- 环球即时:Spring Cloud Gateway过滤器的执行顺序
- 众生药业去年净利润3.22亿元,研发投入3.4亿元|每日头条
- 天天速讯:双汇发展:公司2022年度利润分配预案尚待公司股东大会审议批准后方可实施,敬请关注公司后续相关公告
- 热议:地铁乘客将享极速5G网速,上海电信全球首创“车地系统”
- 金太宗被臣下当众殴打
- 全球观焦点:永联丰控股客户及供应商集中度双高,市场份额占比不足1%
- 环球要闻:中信证券新增上市证券做市交易业务
- 沙尘天气已到达河南!持续到何时?最新消息来了……_今日最新
- 贵阳大数据交易所与国家发改委价格监测中心签署合作协议
- 每日焦点!用人担保合同范本(精选40篇)
- 邓正红能源软实力:“欧佩克+”减产大背景下的欧美原油期货整体表现强势_天天简讯
- 快讯:港股中资券商股走强,东方证券涨超7%
- 东风风行菱智新能源正式上市 售13.99万元起|世界速看料
- 焦点信息:如皋构建引才聚才强磁场
- u盘怎样安装win8系统 下文为你带来u盘安装win8系统方法-全球观天下
- 天天头条:爱驰汽车命悬一线,已停工停薪,今年仅卖出55辆
- 古尔库夫卡卡_古尔库夫号码_当前热门
- 开始了?一地清理编外人员326人,节省财政约1500万!
- 邯郸市交巡警支队磁县大队持续开展驾乘电动自行车佩戴安全头盔专项整治集中行动
- 四川一季度天然气产量139亿立方米,同比增长7.43% 今日视点
- 销量狂飙、节能3倍:热泵为何突然成为减碳“神器”
- 曼联为新队魂标价5000万,不愿卖给纽卡!新中场难买欲强留做替补_每日热点
- 天天速看:Mysteel日报:国内钼市情绪低弱 价格博弈持续
- 【世界聚看点】我国又一座大型火车站开工!规模:14台30线
- 盈利大增!锂电、光伏千亿公司披露一季报预告
- 如何传播蓝色地毯杜松_生日礼物送什么 女生
- 环球最资讯丨中国国贸:根据公司与客户签署的合同,公司收取租金或其他费用基本以人民币进行计价和结算
- 【速看料】新股N南矿上午收盘涨97.53%
- 广东省工业系统举行关爱女职工现场经验交流会
- 原神角色详情在哪打开_热闻