Spring-Cloud-Gateway源码分析系列 | Spring-Cloud-Gateway之请求处理流程

本文深入探讨了Spring Cloud Gateway的请求处理流程,从DispatcherHandler的调度开始,通过RoutePredicateHandlerMapping进行路由查找和匹配,然后由FilteringWebHandler使用Filter链表处理请求。详细分析了每个组件的作用和执行顺序,有助于理解Spring Cloud Gateway的工作原理。
摘要由CSDN通过智能技术生成
推荐 Spring Boot/Cloud 视频:

Spring-Cloud-Gateway 初始化,路由模型,以及路由加载等源码在上几篇学习文档中已经描述,接下来来看Spring-Cloud-Gateway是怎么通过这些来对我们的请求进行路由处理的

Spring-Cloud-Gateway整体流程图

在这里插入图片描述

  • DispatcherHandler:所有请求的调度器,负载请求分发
  • RoutePredicateHandlerMapping:路由谓语匹配器,用于路由的查找,以及找到路由后返回对应的WebHandler,DispatcherHandler会依次遍历HandlerMapping集合进行处理
  • FilteringWebHandler : 使用Filter链表处理请求的WebHandler,RoutePredicateHandlerMapping找到路由后返回对应的FilteringWebHandler对请求进行处理,FilteringWebHandler负责组装Filter链表并调用链表处理请求。
DispatcherHandler

org.springframework.web.reactive.DispatcherHandler

    @Override
    public Mono<Void> handle(ServerWebExchange exchange) {
        if (logger.isDebugEnabled()) {
            ServerHttpRequest request = exchange.getRequest();
            logger.debug("Processing " + request.getMethodValue() + " request for [" + request.getURI() + "]");
        }
        //校验handlerMapping集合是否为空
        if (this.handlerMappings == null) {
            return Mono.error(HANDLER_NOT_FOUND_EXCEPTION);
        }
        //依次遍历handlerMapping集合进行请求处理
        return Flux.fromIterable(this.handlerMappings)
                .concatMap(mapping ->
                //通过mapping获取mapping对应的handler
                mapping.getHandler(exchange))
                .next()
                .switchIfEmpty(Mono.error(HANDLER_NOT_FOUND_EXCEPTION))
                .flatMap(handler -> 
                //调用handler处理
                invokeHandler(exchange, handler))
                .flatMap(result -&g
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值