在上一篇文章当中,大家对Spring Cloud GateWay有了一个初步的认识,网关作为一个系统的流量入口,有着举足轻重的作用。
网关的作用:
(1)、协议转换、路由转发。
(2)、流量控制。
(3)、权限判断。
(4)、缓存。
流程详述:客户端向Spring Cloud GateWay发出请求,GateWay Handler Mapping 确定与之对应的路由,然后再发送到GateWay Web Handler进行处理。GateWay Web Handler会经过过滤器链。过滤器链划分虚线的原因是过滤器链在发出代理请求之前和代理之后会处理过滤逻辑,先处理“pre”的过滤逻辑,然后再发出代理请求。在发出代理请求之后,收到代理服务的响应之后处理“post”的过滤逻辑。在执行所有“pre”过滤逻辑时,往往进行了鉴权、限流、日志输出等功能,以及请求头的更改、协议的转换;转发之后收到响应之后,会执行所有“post”过滤器的逻辑,在这里可以响应数据进行了修改,比如响应头、协议的转换等。
Spring Cloud有很多的Predict,如下图:
1、准备工作
基于上一篇文章,我们创建一个子工程,工程名字叫做:spring-cloud-gateway-predicate
2、引入相关依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.brimen</groupId>
<artifactId>spring-cloud-brimen-gateway</artifactId>
<version>1.0-SNAPSHOT</version>
<relativePath/>
</parent>
<groupId>com.brimen</groupId>
<artifactId>spring-cloud-gateway-predicate</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>spring-cloud-gateway-predicate</name>
<description>Spring Cloud 网关断言</description>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
3、配置各种predicate
(1)、After Route Predicate Factory
AfterRoutePredicateFactory,可配置一个时间,当请求的时间在配置时间之后,才交给 router去处理。否则则报错,不通过路由。
在工程的application.yml配置如下:
server:
port: 8081
spring:
profiles:
active: after-route
然后再新建一个配置文件,配置predicate,代码如下:
spring:
cloud:
gateway:
routes:
- id: after_route
uri: http://example.org
predicates:
- After=2018-09-20T17:42:47.789-07:00[America/Denver]
上面的配置文件当中id是route的id;url是当满足predicates的条件下,路由请求到哪里;after当请求的时间在配置时间之后,才交给 router去处理。
当请求的时间在这个配置的时间之后,请求会被路由到 http://example.org
(2)、Header Route Predicate Factory
Header Route Predicate Factory需要2个参数,一个是header名,另外一个header值,该值可以是一个正则表达式。当此断言匹配了请求的header名和值时,断言通过,进入到router的规则中去。
spring:
cloud:
gateway:
routes:
- id: header_route
uri: http://httpbin.org/get
predicates:
- Header=X-Request-Id, \d+
profiles: header-route
在上面的配置中,当请求的Header中有X-Request-Id的header名,且header值为数字时,请求会被路由到配置的 uri. 使用curl执行以下命令:
curl -H 'X-Request-Id:1' localhost:8081
执行命令后,会正确的返回请求结果,结果省略。如果在请求中没有带上X-Request-Id的header名,并且值不为数字时,请求就会报404,路由没有被正确转发