一、引言

在微服务架构中,API网关是流量的统一入口,承担着路由转发、流量管控、安全防护等核心职责。Spring Cloud Gateway作为Spring官方推荐的第二代网关,基于Spring 5.0、Spring Boot 2.0和Project Reactor构建,提供了高性能的响应式编程模型和丰富的扩展能力。相比 Zuul 1.x,它采用响应式编程模型,能够更高效地处理高并发场景。
本文将从基础入手,深入讲解路由、断言、过滤器、负载均衡及与Nacos的集成,帮助读者快速掌握Gateway的核心技术。

二、核心概念与基础架构

Spring Cloud Gateway 是 Spring Cloud 生态中基于 WebFlux 构建的高性能响应式 API 网关,定位为替代传统的 Zuul 网关。其核心价值在于提供统一的路由管理、流量控制、安全防护等功能,成为微服务架构的 “统一入口”。

2.1 核心组件

Spring Cloud Gateway的核心由三大组件构成:

  • 路由(Route):路由是网关的基本单元,包含ID、目标URI、断言和过滤器。
  • 断言(Predicate):用于匹配请求条件(如路径、参数、时间等),决定请求是否匹配当前路由。
  • 过滤器(Filter):分为全局过滤器(GlobalFilter)和局部过滤器(GatewayFilter),用于请求/响应的预处理和后处理。

2.2 核心功能

  • 路由转发:根据请求规则将请求分发到不同微服务
  • 负载均衡:集成 Spring Cloud LoadBalancer 实现动态负载均衡
  • 过滤链:通过 Filter 链实现请求预处理和响应后处理
  • 动态配置:支持配置中心动态更新路由规则
  • 安全防护:集成 Spring Security 实现认证授权

2.3 核心优势

  • 高性能:基于WebFlux的非阻塞IO模型,吞吐量比传统网关提升30%以上。
  • 动态路由:支持从Nacos、Redis等动态加载路由规则,无需重启服务。
  • 丰富的生态:内置30+开箱即用的过滤器,支持插件化扩展。

三、路由与断言:网关的核心逻辑

3.1 路由配置基础

路由配置通常在application.yml中定义,示例如下:

spring:cloud:gateway:routes:- id: user-service-routeuri: lb://user-service # 负载均衡服务名predicates:- Path=/api/user/** # 路径匹配filters:- StripPrefix=1 # 移除路径前缀

3.2 断言(Predicate)详解

断言是路由匹配的核心条件,Spring Cloud Gateway提供了多种内置断言工厂。
在这里插入图片描述

3.2.1 路径匹配断言(Path)
  • 语法Path=/path/**
  • 示例:匹配以/api/user/开头的所有路径
predicates:- Path=/api/user/**
3.2.2 参数匹配断言(Query)
  • 语法Query=param[,regex]
  • 示例:匹配包含token参数且值以Bearer_开头的请求
predicates:- Query=token,Bearer_.*
3.2.3 IP段匹配断言(RemoteAddr)
  • 语法RemoteAddr=192.168.1.0/24
  • 示例:仅允许来自192.168.1.0/24网段的请求
predicates:- RemoteAddr=192.168.1.0/24
3.2.4 时间范围断言(Between)
  • 语法Between=startTime,endTime
  • 示例:仅在2023-01-01至2023-12-31之间的请求生效
predicates:- Between=2023-01-01T00:00:00+08:00,2023-12-31T23:59:59+08:00
3.2.5 组合断言(逻辑运算符)
  • 语法:使用()组合多个断言
  • 示例:匹配路径为/api/user且请求方法为POST的请求
predicates:- (Path=/api/user && Method=POST)
3.2.6 流量分配断言(Weight)
  • 语法Weight=group,weight
  • 示例:将80%的流量转发到weighthigh.org,20%转发到weightlow.org
routes:- id: weight_highuri: https://weighthigh.orgpredicates:- Weight=group1,8- id: weight_lowuri: https://weightlow.orgpredicates:- Weight=group1,2

四、过滤器:请求与响应的精细化控制

4.1 过滤器分类

  • 全局过滤器(GlobalFilter):对所有路由生效,需实现GlobalFilter接口。
  • 局部过滤器(GatewayFilter):仅对当前路由生效,通过配置文件定义。
  • 默认过滤器(default-filters):对所有路由生效,配置在spring.cloud.gateway.default-filters中。

4.2 内置过滤器示例

4.2.1 添加请求头(AddRequestHeader)
filters:- AddRequestHeader=X-Request-Id,${random.uuid}
4.2.2 移除路径前缀(StripPrefix)
filters:- StripPrefix=1 # 移除第一个路径段
4.2.3 限流过滤器(RequestRateLimiter)
filters:- name: RequestRateLimiterargs:key-resolver: "#{@remoteAddrKeyResolver}" # 基于IP限流redis-rate-limiter.replenishRate: 10 # 每秒生成10个令牌redis-rate-limiter.burstCapacity: 20 # 令牌桶容量

4.3 自定义全局过滤器

@Component
@Order(-1) // 优先级:数值越小,执行越早
public class AuthFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {String token = exchange.getRequest().getHeaders().getFirst("Authorization");if (token == null || !token.startsWith("Bearer ")) {exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);return exchange.getResponse().setComplete();}return chain.filter(exchange); // 放行请求}
}

五、负载均衡:与Nacos的深度集成

5.1 服务注册与发现

  1. 引入依赖
<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>
  1. 配置Nacos
spring:cloud:nacos:discovery:server-addr: localhost:8848 # Nacos服务地址gateway:discovery:locator:enabled: true # 启用服务发现路由lower-case-service-id: true # 服务名小写
  1. 路由配置
routes:- id: user-serviceuri: lb://user-service # 负载均衡服务名predicates:- Path=/api/user/**

5.2 负载均衡策略配置

默认使用轮询策略,可通过@LoadBalancerClient指定其他策略:

@Configuration
public class LoadBalancerConfig {@Beanpublic ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,ServiceInstanceListSupplier supplier) {return new RandomLoadBalancer(environment, supplier); // 随机策略}
}@LoadBalancerClient(name = "user-service", configuration = LoadBalancerConfig.class)
public interface UserClient {// Feign客户端接口
}

六、与Nacos的动态路由集成

6.1 动态路由配置

  1. 在Nacos控制台创建配置文件
# Data ID: gateway-routes.yaml
spring:cloud:gateway:routes:- id: product-serviceuri: lb://product-servicepredicates:- Path=/api/product/**filters:- StripPrefix=1
  1. 在网关服务中加载配置
spring:cloud:config:import: "optional:nacos:gateway-routes.yaml"
  1. 动态刷新路由
curl -X POST http://localhost:8080/actuator/gateway/refresh

6.2 动态服务发现

网关会自动从Nacos获取服务实例列表,实现动态负载均衡:

uri: lb://product-service # 自动发现服务实例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/92428.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/92428.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/92428.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于springboot的乡村旅游在线服务系统/乡村旅游网站

管理员&#xff1a;登录&#xff0c;个人中心&#xff0c;用户管理&#xff0c;景点类型管理&#xff0c;旅游景点管理&#xff0c; 酒店信息管理&#xff0c;旅游线路管理&#xff0c;门票预订管理&#xff0c;酒店预订管理&#xff0c;旅游攻略管理&#xff0c;社区互动&…

JavaWeb笔记12

登录的问题&#xff1a;用户两次登录后会生成新旧两个令牌&#xff0c;此时旧的不应该生效要使旧的失效&#xff1a;令牌主动失效机制 登录成功后&#xff0c;给浏览器响应令牌的同时&#xff0c;把该令牌存储到redis中 LoginInterceptor拦截器中&#xff0c;需要验证浏览器携带…

算法牢笼与思想飞地:在人工智能时代守卫灵魂的疆域

当手指在键盘上敲下“帮我写一篇关于XX的文章”&#xff0c;当屏幕上的“智能助手”瞬间输出结构完整、引经据典的文字&#xff0c;当算法为我们精准推送“你可能感兴趣”的一切——我们正被一种前所未有的认知便利所包围。然而&#xff0c;在这层包裹着效率与舒适的华丽外衣之…

WebAssembly浏览器指纹识别技术——实验评估与应用展望(下篇)

引言 在上篇文章中,我们详细阐述了基于WebAssembly的浏览器指纹识别技术的理论基础和核心方法。本文将进一步展示该技术在实际应用中的表现,通过大规模的实验验证其有效性,并深入探讨相应的防护策略。同时,我们也将客观分析该技术的应用前景与潜在风险,为相关领域的研究和…

kafka--基础知识点--5.4--max.in.flight.requests.per.connection

一、参数定义 max.in.flight.requests.per.connection 是 Kafka 生产者客户端配置参数&#xff0c;用于控制生产者与单个 Broker 连接中未确认请求的最大数量。简单来说&#xff0c;它限制了生产者在等待之前发送的消息确认&#xff08;ACK&#xff09;时&#xff0c;可以同时向…

【Spring AI 0基础教程】1、基础篇 环境搭建 - 智能天气预报助手

基础篇 | 环境搭建 - 智能天气预报助手 一、什么是 Spring AI Spring AI (https://spring.io/projects/spring-ai)]是 Spring 官方于 2023 年推出的 AI 应用开发框架&#xff0c;它如同 AI 世界的"Spring 生态连接器"&#xff0c;致力于简化开发集成了 AI 功能的应…

深入浅出MyBatis缓存:如何让数据库交互飞起来

深入浅出MyBatis缓存&#xff1a;如何让数据库交互飞起来你是否遇到过这样的场景&#xff1a;系统在高并发下响应缓慢&#xff0c;数据库监控显示CPU飙升&#xff0c;日志里充斥着大量重复SQL&#xff1f;作为开发者&#xff0c;我曾亲眼目睹一个简单的配置查询拖垮整个系统。今…

【计算机考研(408)- 数据结构】绪论

绪论 基本概念&#xff08;理解即可&#xff09; 数据是信息的载体&#xff0c;是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别 和处理的符号的集合。数据是计算机程序加工的原料。&#xff08;For Example : 声音/图像/字符串等&#xff09; 数据元…

嵌入式学习-土堆PyTorch(9)-day25

进入尾声&#xff0c;一个完整的模型训练 &#xff0c;点亮的第一个led#自己注释版 import torch import torchvision.datasets from torch import nn from torch.utils.tensorboard import SummaryWriter import time # from model import * from torch.utils.data import Dat…

Java变量详解:局部变量、成员变量、类变量区别及使用场景

作为Java开发者&#xff0c;深入理解不同变量的特性是写出高质量代码的基础。本文将为你全面解析三种核心变量类型&#xff0c;并通过实战案例展示它们的正确使用方式。一、变量类型概览 1. 局部变量&#xff08;Local Variable&#xff09; 定义&#xff1a;在方法、构造方法或…

【收集电脑信息】collect_info.sh

收集电脑信息 collect_info.sh #!/bin/bashoutput"info.txt" > "$output"# 1. OS Version echo " 操作系统名称及版本 " >> "$output" lsb_release -d | cut -f2- >> "$output" echo -e "\n" >…

服务器清理空间--主要是conda环境清理和删除

1.查看空间情况 (base) zhouy24RL-DSlab:~/zhouy24Files$ df -h Filesystem Size Used Avail Use% Mounted on udev 252G 0 252G 0% /dev tmpfs 51G 4.9M 51G 1% /run /dev/nvme0n1p3 1.9T 1.7T 42G 98% / tmpfs 252G …

UE5多人MOBA+GAS 26、为角色添加每秒回血回蓝(番外:添加到UI上)

文章目录添加生命值和蓝量的状态标签创建无限GE并应用监听添加和去除标签每秒回复配上UI添加生命值和蓝量的状态标签 添加新的标签 CRUNCH_API UE_DECLARE_GAMEPLAY_TAG_EXTERN(Stats_Health_Full)CRUNCH_API UE_DECLARE_GAMEPLAY_TAG_EXTERN(Stats_Health_Empty)CRUNCH_API U…

MetaGPT源码剖析(三):多智能体系统的 “智能角色“ 核心实现——Role类

每一篇文章都短小精悍&#xff0c;不啰嗦。今天我们来深入剖析Role类的代码实现。在多智能体协作系统中&#xff0c;Role&#xff08;角色&#xff09;就像现实世界中的 "员工"&#xff0c;是执行具体任务、参与协作的基本单位。这段代码是 MetaGPT 框架的核心&#…

【项目经验】小智ai MCP学习笔记

理论 1、什么是MCP MCP(Model Context Protocol&#xff0c;模型上下文协议)是一种开放式协议&#xff0c;它实现了LLM与各种工具的调用。使LLM从对话、生成式AI变成了拥有调用三方工具的AI。用官方的比喻&#xff0c;MCP就是USB-C接口&#xff0c;只要实现了这个接口&#x…

Matlab学习笔记:矩阵基础

MATLAB学习笔记:矩阵基础 作为MATLAB的核心,矩阵是处理数据的基础工具。矩阵本质上是一个二维数组,由行和列组成,用于存储和操作数值数据。在本节中,我将详细讲解矩阵的所有知识点,包括创建、索引、运算、函数等,确保内容通俗易懂。我会在关键地方添加MATLAB代码示例,…

技术演进中的开发沉思-38 MFC系列:关于打印

打印程序也是MFC开发中不能忽视的一个环节&#xff0c;现在做打印开发so easy。但当年做打印开发还是挺麻烦。在当年的桌面程序里就像拼图的最后一块&#xff0c;看着简单&#xff0c;实则要把屏幕上的像素世界&#xff0c;准确映射到打印机的物理纸张上。而MFC 的打印机制就像…

Apache Ignite 长事务终止机制

这段内容讲的是 Apache Ignite 中长事务终止机制&#xff08;Long Running Transactions Termination&#xff09;&#xff0c;特别是关于分区映射交换&#xff08;Partition Map Exchange&#xff09;与事务超时设置&#xff08;Transaction Timeout&#xff09;之间的关系。下…

网络编程---TCP协议

TCP协议基础知识TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是互联网核心协议之一&#xff0c;位于传输层&#xff08;OSI第4层&#xff09;&#xff0c;为应用层提供可靠的、面向连接的、基于字节流的数据传输服务。它与IP协议共同构成…

K 近邻算法(K-Nearest Neighbors, KNN)详解及案例

K近邻算法&#xff08;K-Nearest Neighbors, KNN&#xff09;详解及案例 一、基本原理 K近邻算法是一种监督学习算法&#xff0c;核心思想是“物以类聚&#xff0c;人以群分”&#xff1a;对于一个新样本&#xff0c;通过计算它与训练集中所有样本的“距离”&#xff0c;找出距…