当前位置: 首页 > 文档资料 > SOP 中文文档 >

原理分析之如何路由

优质
小牛编辑
134浏览
2023-12-01

Spring Cloud Gateway通过一系列的Filter来进行数据的传输,如下图所示:

流程图

SOP网关在此基础上新增了几个Filter用来处理自己的逻辑,如:前置校验、结果返回。

过滤器类型Order功能
IndexFilter自定义-2147483648入口过滤器,获取参数、签名校验
ParameterFormatterFilter自定义-2147482647格式化参数
LimitFilter自定义-2147482447限流
ForwardPathFilter系统自带0设置转发的path
RouteToRequestUrlFilter系统自带10000设置转发host
SopLoadBalancerClientFilter自定义10100LoadBalance获取转发实例
NettyRoutingFilter系统自带2147483647获取httpclient发送请求
ForwardRoutingFilter系统自带2147483647请求分发
GatewayModifyResponseGatewayFilter自定义-2处理响应结果

一个完整的请求会自上而下经过这些Filter,下面讲解如何动态设置路由。

动态设置路由

网关启动后会从注册中心拉取微服务实例,然后请求微服务提供的一个接口(/sop/routes),获取开放接口信息(被@Open注解的接口)。

监听处理类在:com.gitee.sop.bridge.route.NacosRegistryListener

获取到路由信息后,将路由信息缓存到本地,并保存到数据库,代码在:com.gitee.sop.gatewaycommon.gateway.route.GatewayRouteCache.load

然后动态设置Gateway路由,代码在:com.gitee.sop.gatewaycommon.gateway.route.GatewayRouteRepository.refresh

当有微服务重新启动时,网关会监听到微服务实例有变更,会重复上述步骤,确保网关存有最新的路由。