gateway原理

在这里插入图片描述
流量进入网关后先进入handler mapping 进行匹配具体的route ,再通过handler 处理route。处理请求的时候经过过滤器链处理一系列过滤器(包括route中的自定义filter和系统自带的全局过滤器)进请求处理,最终到达被代理的服务。

在这里插入图片描述
GatewayProperties用于从配置文件中加载前缀为 spring.cloud.gateway的配置信息
在这里插入图片描述
spring gateway 接收请求流程
在这里插入图片描述

解析配置文件,生成元素为Route对象的集合。然后根据request中的URL匹配其中的某条Route对象。
↓↓↓
在这里插入图片描述
然后将路由信息放到上下文
在这里插入图片描述
同时获取对应的handler,用于invokeHandler方法的参数
在这里插入图片描述

寻找到路由后,执行处理过程
在这里插入图片描述

从route中的取出自定义过滤器,然后和全局过滤器(如负载均衡过滤器)合并,并排序(排序原理)。然后将集合放到过滤器链中。之后执行所有的过滤器。
在这里插入图片描述

负载均衡过滤器
获取route对象中的URL及微服务名称(如果URL是纯连接)。从容器中获取一个loadBalancer对象,同时根据serviceId从服务注册中心获取对应的URL。再使用轮询策略获取url。然后在将访问到gateway的地址替换成服务的请求地址,使用httpClient 进行访问。

猜你喜欢

转载自blog.csdn.net/qq_41948178/article/details/109480168