微服务入门-Spring Cloud Gateway路由配置详解?
ztj100 2024-10-29 18:19 26 浏览 0 评论
在之前的分享中,我们介绍了Spring Cloud Gateway微服务网关技术,并且知道了Spring Cloud Gateway提供了很多灵活的方式来配置和管理路由请求、过滤请求、转换协议等。下面我们就来看看Spring Cloud Gateway如何实现路由配置的。
路由搜索引擎
搭建Spring Boot项目,并且引入Gateway相关的依赖,如下所示。
<!-- SpringCloud Gateway -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
添加路由百度的的配置路由配置,如下所示。
server:
port: 4000
# application.yml
spring:
cloud:
gateway:
routes:
- id: example_route
uri: https://www.baidu.com
predicates:
- Path=/**
这个时候,我们启动项目之后就访问http://localhost:4000/就可以看到如下的效果了。
居然在本地localhost上访问的到了搜索引擎的的首页,这个是个什么原理?下面我们就来一起探索一下Spring Cloud Gateway路由配置相关的内容吧?
Gateway路由配置介绍
如下所示,是我们在上面的例子中提供的一个简单的路由配置规则。
spring:
cloud:
gateway:
routes:
- id: example_route
uri: https://www.baidu.com/s
predicates:
- Path=/baidu/**
filters:
- RewritePath=/baidu/(?<segment>.*), /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>.*), /$\{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<CustomLoggingGatewayFilterFactory.Config> {
@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<String> 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的路由匹配规则的使用,并且介绍如何自定义过滤操作,根据不同的路由匹配规则可以实现动态的路由配置调整,来满足我们的业务需求。
相关推荐
- 如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL
-
阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...
- Python数据分析:探索性分析
-
写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...
- C++基础语法梳理:算法丨十大排序算法(二)
-
本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...
- C 语言的标准库有哪些
-
C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...
- [深度学习] ncnn安装和调用基础教程
-
1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...
- 用rust实现经典的冒泡排序和快速排序
-
1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...
- ncnn+PPYOLOv2首次结合!全网最详细代码解读来了
-
编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- Qt4/5升级到Qt6吐血经验总结V202308
-
00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...
- 到底什么是C++11新特性,请看下文
-
C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...
- 掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!
-
C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...
- 经典算法——凸包算法
-
凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...
- 一起学习c++11——c++11中的新增的容器
-
c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...
- C++ 编程中的一些最佳实践
-
1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)