微服务入门-Spring Cloud Gateway路由配置详解?
ztj100 2024-10-29 18:19 34 浏览 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的路由匹配规则的使用,并且介绍如何自定义过滤操作,根据不同的路由匹配规则可以实现动态的路由配置调整,来满足我们的业务需求。
相关推荐
- Python 操作excel的坑__真实的行和列
-
大佬给的建议__如何快速处理excelopenpyxl库操作excel的时候,单个表的数据量大一些处理速度还能接受,如果涉及多个表甚至多个excel文件的时候速度会很慢,还是建议用pandas来处理,...
- Python os.path模块使用指南:轻松处理文件路径
-
前言在Python编程中,文件和目录的操作是非常重要的一部分。为了方便用户进行文件和目录的操作,Python标准库提供了os模块。其中,os.path子模块提供了一些处理文件路径的函数和方法。本文主要...
- Python常用内置模块介绍——文件与系统操作详解
-
Python提供了多个强大的内置模块用于文件和系统操作,下面我将详细介绍最常用的几个模块及其核心功能。1.os模块-操作系统交互...
- Python Flask 建站框架实操教程(flask框架网页)
-
下面我将带您从零开始构建一个完整的Flask网站,包含用户认证、数据库操作和前端模板等核心功能。##第一部分:基础项目搭建###1.创建项目环境```bash...
- 为你的python程序上锁:软件序列号生成器
-
序列号很多同学可能开发了非常多的程序了,并且进行了...
- PO设计模式全攻略,在 UI 自动化中的实践总结(以企业微信为例)
-
一、什么是PO设计模式?PO(PageObject)设计模式将某个页面的所有元素对象定位和对元素对象的操作封装成一个Page类,即一个py文件,并以页面为单位来写测试用例,实现页面对象和测试用例的...
- 这种小工具居然也能在某鱼卖钱?我用Python一天能写...
-
前两天在某鱼闲逛,本来想找个二手机械键盘,结果刷着刷着突然看到有人在卖——Word批量转PDF小工具...
- python打包成exe,程序有图标,但是任务栏和窗口都没有显示图标
-
代码中指定图标信息#设置应用ID,确保任务栏图标正确显示ifsys.platform=="win32":importctypesapp_id=...
- 使用Python构建电影推荐系统(用python做推荐系统)
-
在日常数据挖掘工作中,除了会涉及到使用Python处理分类或预测任务,有时候还会涉及推荐系统相关任务。...
- python爬取并分析淘宝商品信息(python爬取淘宝商品数据)
-
python爬取并分析淘宝商品信息背景介绍一、模拟登陆二、爬取商品信息1.定义相关参数2.分析并定义正则3.数据爬取三、简单数据分析1.导入库2.中文显示3.读取数据4.分析价格分布5.分析销售...
- OpenCV入门学习基础教程(从小白变大神)
-
Opencv是用于快速处理图像处理、计算机视觉问题的工具,支持多种语言进行开发如c++、python、java等,下面这篇文章主要给大家介绍了关于openCV入门学习基础教程的相关资料,需要的朋友可以...
- python图像处理-一行代码实现灰度图抠图
-
抠图是ps的最基本技能,利用python可以实现用一行代码实现灰度图抠图。基础算法是...
- 从头开始学python:如何用Matplotlib绘图表
-
Matplotlib是一个用于绘制图表的库。如果你有用过python处理数据,那Matplotlib可以更直观的帮你把数据展示出来。直接上代码看例子:importmatplotlib.pyplot...
- Python爬取爱奇艺腾讯视频 250,000 条数据分析为什么李诞不值得了
-
在《Python爬取爱奇艺52432条数据分析谁才是《奇葩说》的焦点人物?》这篇文章中,我们从爱奇艺爬取了5万多条评论数据,并对一些关键数据进行了分析,由此总结出了一些明面上看不到的数据,并...
- Python Matplotlib 库使用基本指南
-
简介Matplotlib是一个广泛使用的Python数据可视化库,它可以创建各种类型的图表、图形和可视化效果。无论是简单的折线图还是复杂的热力图,Matplotlib提供了丰富的功能来满足我们...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Python 操作excel的坑__真实的行和列
- Python os.path模块使用指南:轻松处理文件路径
- Python常用内置模块介绍——文件与系统操作详解
- Python Flask 建站框架实操教程(flask框架网页)
- 为你的python程序上锁:软件序列号生成器
- PO设计模式全攻略,在 UI 自动化中的实践总结(以企业微信为例)
- 这种小工具居然也能在某鱼卖钱?我用Python一天能写...
- python打包成exe,程序有图标,但是任务栏和窗口都没有显示图标
- 使用Python构建电影推荐系统(用python做推荐系统)
- python爬取并分析淘宝商品信息(python爬取淘宝商品数据)
- 标签列表
-
- 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)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- 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)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)