gateway原理

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

gateway原理_第2张图片
GatewayProperties用于从配置文件中加载前缀为 spring.cloud.gateway的配置信息
gateway原理_第3张图片
spring gateway 接收请求流程
gateway原理_第4张图片

解析配置文件,生成元素为Route对象的集合。然后根据request中的URL匹配其中的某条Route对象。
↓↓↓
gateway原理_第5张图片
然后将路由信息放到上下文
gateway原理_第6张图片
同时获取对应的handler,用于invokeHandler方法的参数
gateway原理_第7张图片

寻找到路由后,执行处理过程
gateway原理_第8张图片

从route中的取出自定义过滤器,然后和全局过滤器(如负载均衡过滤器)合并,并排序(排序原理)。然后将集合放到过滤器链中。之后执行所有的过滤器。
gateway原理_第9张图片

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

你可能感兴趣的:(后台程序员,spring)