gateway+sentinel+nacos流程

       filteringWebHandler (前置route predict判断) 限流和服务调用都通过filterChain调用实现的filter类处理

       SentinelGatewayFilter 通过GatewayRouleManager注册关联的配置限制GatewayFlowRule

StripPrefixGatewayFIlter

      FowardPathFilter判断是否forwad调用

      RouteToRequestUrlFilter route 调用子服务

       LoadBalancerClientFilter (可自定义IRule接口,通过参数控制结合jekins 优雅下线nacos服务)  获取配置的 uri , prefix属性  非lb开头,其他filter处理

  1. 获取原始地址 loadBanancerClient选择获取ServerInstance (nacos -> nacosRobbinClients等clients 配置组装 robbinClient ,可自定义IRule等实现自定义加载)
  2. 这里针对不同的微服务获取对应的ServiceInstance
  3. getLoadBalancer(ServiceId) 根据不同的serviceId生成不同的 applicationContext ( RibbonLoadBalancerClient持有SpringClientFactory对象(netflix-ribbon下) extends NamedContextFactory 通过getInstance生成当前gatewayweb下的applicationContext的子applicationContext; 并注入对应的irule等一系列配置。)                                                         这里自定义配置由@RibbonClients注解配置IRule等,否则会导致多个服务公用配置,无法切换服务。
  4. 通过clientFactory获取ILoadBalancer实例,根据注入规则,choose对应的server获取请求的uri,
  5. 根据ServerInstance, 如果有对应的ServerIntrospector包装,处理转化为实际的uri请求路径,放入请求的ServerWebExchange属性中 
  6. 继续下一个filter请求 nettyroutingfilter执行请求并得到返回结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值