在之前的分享中,我们介绍了Spring Cloud Gateway微服务网关技术,并且知道了Spring Cloud Gateway提供了很多灵活的方式来配置和管理路由请求、过滤请求、转换协议等。下面我们就来看看Spring Cloud Gateway如何实现路由配置的。
路由搜索引擎
搭建Spring Boot项目,并且引入Gateway相关的依赖,如下所示。
org.springframework.cloud
spring-cloud-starter-gateway
添加路由百度的的配置路由配置,如下所示。
server:
port:
# application.yml
spring:
cloud:
gateway:
routes:
- id: example_route
uri: https://www.baidu.com
predicates:
- Path=/**
这个时候,我们启动项目之后就访问http://localhost:/就可以看到如下的效果了。
居然在本地localhost上访问的到了搜索引擎的的首页,这个是个什么原理?下面我们就来一起探索一下Spring Cloud Gateway路由配置相关的内容吧?
Gateway路由配置介绍
如下所示,是我们在上面的例子中提供的一个简单的路由配置规则。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: https://www.baidu.com/s
predicates:
- Path=/baidu/**
filters:
- RewritePath=/baidu/(?.*), /s?wd=$\{segment}
- ID(id):因为在配置中,每个路由规则都需要一个唯一的标识符来区分。而这个ID通常就是用于标识路由规则,这样可以方便在后续的管理和调试中使用。
- URI(uri):这个配置,指定了路由规则的目标 URI,即请求将被转发到的目标服务的地址,如上面的我们将请求转发到了搜索引擎首页
- 谓词(predicates):用于匹配请求的条件,以决定是否应该应用该路由规则。Spring Cloud Gateway 提供了多种预定义的谓词,如 Path、Method、Header 等,可以根据请求的路径、方法、请求头等条件来进行匹配。
- 过滤器(filters):用于对请求进行处理和转换的组件。过滤器可以用于添加请求头、修改请求和响应、进行路由重写、记录日志等。Spring Cloud Gateway 提供了多种预定义的过滤器,也支持自定义过滤器。
- 其他属性:除了上述属性之外,还可以在路由规则中定义其他属性,如断路器配置、负载均衡配置等
Spring Cloud Gateway提供的路由配置中允许我们可以根据具体的需求来定义一个或者多个路由匹配的规则,来控制请求的转发和处理。我们可以通过请求的路径、方法、请求头等条件来匹配路由规则,并通过过滤器对请求进行处理和转换,如上所示,展示了通过路径排进行匹配,并且通过过滤实现了关键字搜索的功能。下面我们就来详细介绍一下这些匹配规则。
通过请求头规则进行路由配置?
上面我们提到再配置路由规则的时候,可以通过路径的方式来进行配置,就如上面的例子中展示的那个样子,我们也可以通过配置请求头的规则来实现路由的配置,如下所示。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Header=X-Custom-Header, value
在这个配置中,我们使用了Header这个谓词逻辑来匹配请求的头部信息。通过定义X-Custom-Header 来表示是请求头的名称,而value是匹配的值。这也就意味着只有当请求头中包含 X-Custom-Header: value 这样的内容时,才会匹配到这个路由规则,将请求转发到 http://example.com。
当然在上面的配置中,X-Custom-Header: value 中的 value 可以是具体的值,这个值用于匹配请求头中的实际内容。当请求头中的值与配置中指定的值完全相同时,才会匹配成功。如下所示。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Header=X-Custom-Header, example
在这个配置规则中,请求头中的X-Custom-Header的值是example,那么只有当路由配置中的值也是 example 时,才会匹配成功。这意味着请求头的值必须与路由配置中指定的值一致,才能触发路由规则。
当然我们也可以通过逻辑运算符来组合请求头中所包含的条件,例如and、or等。如下所示。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Header=X-Custom-Header, value
- Or:
- Header=X-Another-Header, anotherValue
- Header=X-Yet-Another-Header, yetAnotherValue
在这个示例中,我们使用了Or这个逻辑运算符来组合路由匹配的条件。也就是说,如果请求头中的X-Custom-Header的值是value,或者请求头中的 X-Another-Header 的值是 anotherValue,或者请求头中的 X-Yet-Another-Header 的值是 yetAnotherValue,都会触发路由规则,将请求转发到 http://example.com。
通过请求方法来匹配路由?
在HTTP中我们有四种常见的请求方式,分别是GET、POST、PUT、DELETE 等,而在Spring Cloud Gateway中就提供了通过请求方法来匹配路由规则的方式。如下所示。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Method=GET
在这个配置中,我们使用了 Method 谓词来匹配请求的方法。这个路由规则表示只有当请求的方法为GET时,才会触发该路由规则,将请求转发到 http://example.com。当然这种限制,在实际使用的时候并不是太合理,一般情况下,我们也不会这么用。如下所示,才是一个正确的使用方式。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Method=GET
- Path=/api/**
这个配置表示只有当请求的方法为GET的时候,并且请求的路径以 /api/ 开头时,才会触发该路由规则,将请求转发到 http://example.com。
过滤器操作
过滤器是Spring Cloud Gateway中用来对请求和响应进行处理和转换的组件。它可以实现在请求被路由之前(pre)或者之后(post)执行一些逻辑实现一些额外的功能,例如鉴权、日志记录、请求转换、添加头部、修改响应等。
在Spring Cloud Gateway 提供了一些默认的预定义的过滤器,当然同时它也支持自定义过滤器。
默认的预定过滤器
- AddRequestHeader:向请求中添加一个新的头部。
- AddResponseHeader:向响应中添加一个新的头部。
- RewritePath:重写请求的路径。
- RewriteResponseHeader:重写响应的头部。
- SetPath:设置请求的路径。
- SetResponseHeader:设置响应的头部。
- RemoveRequestHeader:移除请求中的某个头部。
- RemoveResponseHeader:移除响应中的某个头部。
- Hystrix:集成断路器模式,用于处理请求时的容错和降级。
- RateLimiter:限流过滤器,用于控制请求的流量。
如下所示,我们在进行过滤器配置的时候,可以指定一个或者是多个的过滤器属性来对请求进行过滤操作。如下所示。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: http://example.com
predicates:
- Path=/api/**
filters:
- AddRequestHeader=X-Custom-Header, value
- RewritePath=/api/(?.*), /$\{segment}
在这个例子中,我们使用了两个过滤器,分别是AddRequestHeader和RewritePath。第一个过滤器用于向请求中添加一个名为X-Custom-Header 的头部,第二个过滤器用于重写请求的路径。这样,当请求匹配到这个路由规则时,会依次执行这两个过滤器对请求进行处理和转换。当然除了使用预设的一些过滤器之外,我们还可以实现自定义的过滤器,如下所示。
自定义过滤器
自定义过滤器可以通过实现 GatewayFilterFactory 接口来实现,在这里我们首先创建了一个名为
CustomLoggingGatewayFilterFactory的日志工厂类,并且在这个类中实现GatewayFilterFactory<
CustomLoggingGatewayFilterFactory.Config> 接口,如下所示。
import org.springframework.cloud.gateway.filter.GatewayFilter;
import org.springframework.cloud.gateway.filter.factory.GatewayFilterFactory;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.stereotype.Component;
import reactor.core.publisher.Mono;
import java.util.Arrays;
import java.util.List;
@Component
public class CustomLoggingGatewayFilterFactory implements GatewayFilterFactory {
@Override
public GatewayFilter apply(Config config) {
return (exchange, chain) -> {
// 打印请求的信息
ServerHttpRequest request = exchange.getRequest();
System.out.println("Request Method: " + request.getMethod());
System.out.println("Request URI: " + request.getURI());
// 继续处理请求链
return chain.filter(exchange);
};
}
@Override
public List shortcutFieldOrder() {
return Arrays.asList();
}
public static class Config {
// 可以定义一些配置参数
}
}
在这个自定义的过滤器中,通过重写apply方法,简单地打印了请求的方法和URI。然后,我们返回一个GatewayFilter对象,用于对请求进行处理。并且在Config类中,我们可以定义一些配置参数,用于在创建过滤器实例时配置过滤器的行为。在这个示例中,我们没有定义任何配置参数,因此shortcutFieldOrder方法返回了一个空的列表。
在路由规则中配置使用,如下所示。
spring:
cloud:
gateway:
routes:
- id: custom_logging_route
uri: http://example.com
predicates:
- Path=/api/**
filters:
- name: CustomLogging
使用我们自定义的过滤器CustomLogging。最终运行程序会在输出日志中看到我们的请求调用的信息。
总结
上面我们介绍了关于SpringCloud Gateway的路由匹配规则的使用,并且介绍如何自定义过滤操作,根据不同的路由匹配规则可以实现动态的路由配置调整,来满足我们的业务需求。