SpringCloudGateway原理——请求如何被Gateway路由转发

Gateway 总览

SpringCloudGateway核心设计基于Route,每个Route含有多个Predicatefilter,当请求满足Route的所有Predicate时,请求会被当前Route接受,之后Route含有的filter会处理请求,所有的核心逻辑处理都在Filter中。

SpringCloudGateway官网架构图非常清晰描述了gateway的工作原理。

Spring Cloud Gateway Diagram

  1. 发送到Gateway的请求会先被RoutePredicateHandlerMapping,如果请求能被Route接受,则返回一个WebHandler。(所谓的接受,就是有配置的Route,请求满足Route含有的所有predicate
  2. WebHandler处理请求,本质就是合并Route含有的filter和全局Filter,对请求进行filter处理。(包括请求重定向、重写header等等功能)
  3. 之后请求会被NettyRoutingFilter处理,转发给目标后端服务。
  4. NettyWriteResponseFilter会将后端返回的数据写入ServerWebExchange response内。
  5. 最后请求返回给前端完成。

Handler Mapping

SpringCloudGateway基于webflux实现,后者有一套自己的服务端框架,为了对其进行适配,SpringCloudGateway提供了RoutePredicateHandlerMapping,用于获取处理请求的WebHandler

RoutePredicateHandlerMapping设计比较简洁,根据请求和配置的Route predicates 查找是否有匹配的Route,如果有匹配的Route则返回FilteringWebHandler,否则返回空请求失败。

HandlerMapping的获取方式如下图:

在这里插入图片描述

FilteringWebHandler在应用初始化时构建传入RoutePredicateHandlerMapping,内部不会对FilteringWebHandler有任何的处理,只要有匹配的Route,就返回FilteringWebHandler;无匹配则请求失败。

匹配成功的Route会被放入ServerWebExchangeattribute内,Route会在WebHandler里被取出。

Web Handler

FilteringWebHandler核心逻辑是构建filter chain,处理RequestWebHandlerhandle方法如下

@Override
public Mono<Void> handle(ServerWebExchange exchange) {
    // 从 ServerWebExchange 里获取 Route
		Route route = exchange.getRequiredAttribute(GATEWAY_ROUTE_ATTR);
    // 获取 Route 下定义的 Filter List
		List<GatewayFilter> gatewayFilters = route.getFilters();
		// 合并全局 Filter List
		List<GatewayFilter> combined = new ArrayList<>(this.globalFilters);
		combined.addAll(gatewayFilters);
  	// 根据 order 排序,这步挺重要的,由于 gateway 基于 filter 实现,所以 filter 的顺序至关重要
		AnnotationAwareOrderComparator.sort(combined);
		if (logger.isDebugEnabled()) {
			logger.debug("Sorted gatewayFilterFactories: " + combined);
		}
  	// filter 处理请求
		return new DefaultGatewayFilterChain(combined).filter(exchange);
}

画张图简化理解

在这里插入图片描述

  • FilteringWebHandler会构建Filter List,合并Route FiltersGlobalFilter List,并进行排序。
  • Filter List处理请求,最后请求会被转发给后端系统。

SpringCloudGateway的请求转发由NettyRoutingFilter实现,后端返回结果由NettyWriteResponseFilter写回ServerWebExchange response内,完成一次gateway转发。

  • 6
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Spring Cloud Gateway是基于Spring Boot 2.x和Spring WebFlux实现的网关服务,提供统一的负载均衡和路由转发的功能。它支持多种路由方式,比如URL路径匹配、请求头匹配、请求参数匹配等等。 路由转发Spring Cloud Gateway的一个重要功能,可以通过路由转发把来自客户端的请求转发到指定的目标服务。路由转发的过程中,网关会根据预定义的路由规则来匹配请求,并选择合适的目标服务进行转发Spring Cloud Gateway路由规则可以通过配置文件或者编程方式进行定义。在配置文件中,可以使用YAML或者Properties格式来定义路由规则。下面是一个YAML格式的路由规则示例: ``` spring: cloud: gateway: routes: - id: my_route uri: http://localhost:8080 predicates: - Path=/my_service/** ``` 这个示例定义了一个名为my_route的路由规则,它会把以/my_service开头的请求转发到http://localhost:8080。 除了Path,Spring Cloud Gateway还支持其他各种路由方式,比如Header、Cookie、Method、Query等等。你可以根据自己的需求选择合适的路由方式。 在路由转发过程中,Spring Cloud Gateway还可以实现负载均衡的功能。它可以根据定义的负载均衡策略来选择合适的目标服务。目前Spring Cloud Gateway支持的负载均衡策略有Round Robin、Weighted Response Time等等。 总之,Spring Cloud Gateway是一个非常强大的网关服务框架,它可以提供统一的负载均衡和路由转发的功能,并且支持多种路由方式和负载均衡策略。如果你的微服务架构需要一个可靠的网关服务,Spring Cloud Gateway是一个非常不错的选择。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值