springcloud官方提供的网关组件spring-cloud-starter-gateway,看pom.xml文件,引入了webflux做响应式编程,请求转发用到了netty的reactor模型。hystrix停止维护后,官方推荐resilience4j做服务熔断,网关这里也能看到依赖。
对于网关提供的功能,大方向上主要是服务路由转发,还有一系列的过滤器。这里过滤器分网关过滤器和全局过滤器两种。
网关过滤器是配置在具体服务下的,只作用于配置对应的服务。gateway组件本身在org.springframework.cloud.gateway.filter.factory内置了很多的网关过滤器,有请求头、请求参数、路径处理、限流、熔断、重试、状态、会话等,定义上都是GatewayFilterFactory结尾的文件名,都实现了org.springframework.cloud.gateway.filter.factory.AbstractGatewayFilterFactory,需要用到配置的时候直接用前置,如需要用到StripPrefixGatewayFilterFactory去除url前置
spring:
gateway<