第二天 f:
为什么需要网关:
网关的功能:
1.身份验证和权限校验。
2.服务路由,负载均衡。
3.请求限流。
springCloud主要的网关实现方式有两种:
一、gateway
二、zuul
其中Zuul是基于Servlet的实现,属于阻塞式编程。
而SpringCloudGateWay则是基于Spring5中提供的WebFlux,属于响应式编程的实现,具有更好的性能。
搭建网关服务:
1.创建新的module,引入SpringCloudGateway的依赖和nacos的服务发现依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud<groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2.编写一个启动类。
3.编写路由配置及nacos地址。配在Gateway下面的application.yml文件下。
server:
port: 10010 #端口号
spring:
application:
name: gateway #服务名称
cloud:
nacos:
server-addr: localhost:8848 # nacos地址
gateway:
routes: # 网关路由配置
-id: user-service # 路由 id,自定义,只要唯一即可
url: lb://userservice #负载均衡
predicates:
- Path=/user/** #选择路径 以/user/..开头,路径断言#
-id: order-service
url: lb://orderservice
predicates:
- Path=/order/**
主要的流程就是这样。
在网关路由中主要的配置有:
1.路由ID:路由唯一标识
2.URL:路由目的地,支持lb和http两种
3.predicates:路由断言,判断请求是否符合要求,符合则转发到路由目的地。
4.filter:路由过滤器,处理请求或者响应。
路由断言工厂(Route Predicate Factory)
1.我们在配置文件中写的断言规则只是字符串,这些字符串会被predicate Factory读取并处理,转变为路由判断的条件。
2.例如Path=/user/**是按照路径匹配,这个规则是由org.springframework.cloud.gateway.handler.predicate.PathRoutePredicateFactory类处理的。
3.像这样的断言工厂在SpringCloudGateway还有十几个。
spring提供的11个断言工厂:
他们的功能都是用于对目标的请求进行一定的判断与筛取。
路由过滤器 GatewayFilter
GatewayFilter是网关提供的一种过滤器,可以对进入网关的请求和微服务返回的响应做处理:
spring提供了31种不同的路由过滤器工厂:
例如:你加了一个请求头:AddRequestHeader
部分路由:这时你要在UserController中加入:
@GetMapping("/{id})
public User queryById(@PathVariable("id") Long id,
@RequestHeader(Value = "Truth",required = false) String truth){
System.out.println("truth:" +truth);
return userService.queryById(id);
}
spring:
cloud:
gateway:
routes:
-id: user-service
url: lb://userservce
predicates:
- Path=/user/**
filters:
-AddRequestHeader=Truth,.....#输入头部
所有路由:但是我们应该怎么样去给所有的请求都加上过滤器,这时需要用到default- filters对于所有路由都生效。
server:
port: 10010 #端口号
spring:
application:
name: gateway #服务名称
cloud:
nacos:
server-addr: localhost:8848 # nacos地址
gateway:
routes: # 网关路由配置
-id: user-service # 路由 id,自定义,只要唯一即可
url: lb://userservice #负载均衡
predicates:
- Path=/user/** #选择路径 以/user/..开头,路径断言#
-id: order-service
url: lb://orderservice
predicates:
- Path=/order/**
default-filters:
- AddRequestHeader=Truth,..........#输入的请求头