网关功能:
1.身份认证和权限校验
2.服务路由、负载均衡
3.请求限流
在SpringCloud中网关的实现包括两种:gateway、zuul
Zuul是基于Servlet的实现,属于阻塞式编程。而SprinaCloudGateway则是基于Spring5中提供的WebFlux,属于响应式编程的实现,具备更好的性能。
搭建网关服务的步骤:
我们在配置文件中写的断言规则只是字符串,这些字符串会被Predicate Factory读取并处理,转变为路由判断的条件
例如Path=/user/**是按照路径匹配,这个规则是由org.springframework.cloud.gateway.handlerpredicate.PathRoutePredicateFactory类来处理的
像这样的断言工厂在SpringCloudGateway还有十几个
Spring提供了11种基本的Predicate工厂:
使用After,访问orderservice微服务的请求,2031年后的请求才可以通过
调用orderservice微服务的接口,发现访问不了了已经
改成Before,也就是2031年以前的请求就可以通过
成功访问
读取用户定义的断言条件,对请求做出判断
路径是以/user开头的就认为是符合的
GatewayFilter是网关中提供的一种过滤器,可以对进入网关的请求和微服务返回的响应做处理
Spring提供了31种不同的路由过滤器工厂。例如:
给所有进入userservice的请求添加一个请求头: Truth=itcastis freaking awesome!
实现方式:在gateway中修改application.yml文件,给userservice的路由添加过滤器
在userservice的一个方法中加入获取到请求头的一个参数,并将该参数打印
调用该接口,发现在控制台中成功打印出参数,说明请求头中确实加入了我们设置的信息
如果要对所有的路由都生效,则可以将过滤器工厂写到default下。格式如下
对路由的请求或响应做加工处理,比如添加请求头
配置在路由下的过滤器只对当前路由的请求生效
对所有路由都生效的过滤器
全局过滤器的作用也是处理一切进入网关的请求和微服务响应,与GatewayFilter的作用一样区别在于GatewayFilter通过配置定义,处理逻辑是固定的。而GlobalFilter的逻辑需要自己写代码实现。定义方式是实现GlobalFilter接口。
需求:定义全局过滤器,拦截请求,判断请求的参数是否满足下面条件:
参数中是否有authorization
authorization参数值是否为admin
如果同时满足则放行,否则拦截
调用该接口并携带响应参数,发现可以调用
参数携带错误,发现调用不了
对所有路由都生效的过滤器,并且可以自定义处理逻辑
实现GlobalFilter接口
添加@Order注解或实现Ordered接口
编写处理逻辑
请求进入网关会碰到三类过滤器: 当前路由的过滤器、DefaultFilter、GlobalFilter
请求路由后,会将当前路由过滤器和DefaultFilter、GlobalFilter,合并到一个过滤器链(集合)中,排序后依次执行每个过滤器
每一个过滤器都必须指定一个int类型的order值,order值越小,优先级越高,执行顺序越靠前
GlobalFilter通过实现Ordered接口,或者添加@Order注解来指定order值,由我们自己指定
路由过滤器和defaultFilter的order由Spring指定,默认是按照声明顺序从1递增
当过滤器的order值一样时,会按照 defaultFilter >路由过滤器>GlobalFilter的顺序执行
order值越小,优先级越高
当order值一样时,顺序是defaultFilter最先,然后是局部的路由过滤器,最后是全局过滤器