欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 时评 > Spring Cloud Gateway 具体的实现案例

Spring Cloud Gateway 具体的实现案例

2025/4/19 6:29:58 来源:https://blog.csdn.net/Bruce__taotao/article/details/147153002  浏览:    关键词:Spring Cloud Gateway 具体的实现案例

文章目录

  • 前言
    • ✅ 1. **创建 Spring Boot 项目**
      • Maven 依赖:
      • Gradle 依赖:
    • ✅ 2. **配置 `application.yml` 路由和过滤器**
      • 解释:
    • ✅ 3. **创建自定义过滤器**
      • 3.1 **前置过滤器(Pre Filter)**
      • 3.2 **后置过滤器(Post Filter)**
      • 3.3 **全局过滤器**
    • ✅ 4. **负载均衡与服务发现**
      • `application.yml` 配置:
    • ✅ 5. **安全性:OAuth2 与 JWT**
      • 配置示例:
    • ✅ 6. **测试和监控**
      • 配置 Actuator:
    • ✅ 总结:


前言

好的,下面我给你提供一个具体的 Spring Cloud Gateway 实现案例。这个案例会涵盖以下内容:

  • 基本配置:如何在 Spring Boot 项目中集成 Spring Cloud Gateway。
  • 路由配置:定义 API 路由规则。
  • 过滤器:如何使用过滤器来处理请求和响应(包括前置过滤器、后置过滤器)。
  • 负载均衡:与服务发现(Eureka)集成,使用负载均衡的 API 网关。
  • 安全性:如何在网关层进行身份验证和授权(例如 OAuth2)。

✅ 1. 创建 Spring Boot 项目

确保你的 pom.xmlbuild.gradle 中包含以下依赖。

Maven 依赖:

<dependencies><!-- Spring Boot Starter WebFlux (需要使用异步/非阻塞的 WebFlux 作为 Gateway 基础) --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency><!-- Spring Cloud Gateway --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!-- Spring Cloud Config (可选,用于集中配置管理) --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency><!-- Eureka Client (可选,服务发现) --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><!-- Spring Boot Actuator (可选,用于监控和健康检查) --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency>
</dependencies>

Gradle 依赖:

dependencies {implementation 'org.springframework.boot:spring-boot-starter-webflux'implementation 'org.springframework.cloud:spring-cloud-starter-gateway'implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'implementation 'org.springframework.boot:spring-boot-starter-actuator'
}

✅ 2. 配置 application.yml 路由和过滤器

src/main/resources/application.yml 配置文件中,你可以定义基本的路由规则,类似于下面的例子:

spring:cloud:gateway:routes:- id: route_to_service_1uri: http://localhost:8081  # 目标服务的 URIpredicates:- Path=/service1/**  # 请求路径为 /service1/** 的请求将被路由到此服务filters:- AddRequestHeader=X-Request-Foo, Bar  # 添加请求头- RewritePath=/service1/(?<segment>.*), /${segment}  # 重写路径- id: route_to_service_2uri: lb://SERVICE2  # 使用负载均衡路由到 Eureka 注册的 SERVICE2 服务predicates:- Path=/service2/**# 自定义的全局过滤器default-filters:- name: RequestRateLimiterargs:redis-rate-limiter.replenishRate: 10redis-rate-limiter.burstCapacity: 20

解释:

  • uri:指定目标服务的 URI,可以是本地服务的地址(如 http://localhost:8081),也可以是通过服务发现(如 Eureka)的服务名(如 lb://SERVICE2)。
  • predicates:定义请求路由的条件。此例中,所有以 /service1/** 为路径的请求都会被路由到 http://localhost:8081
  • filters:对请求或响应进行修改(如添加请求头、重写路径等)。
  • RequestRateLimiter:用于限制请求的频率,可以防止滥用接口。

✅ 3. 创建自定义过滤器

Spring Cloud Gateway 允许你编写自定义的过滤器来对请求进行处理。

3.1 前置过滤器(Pre Filter)

前置过滤器用于在请求转发到目标服务之前处理请求,例如记录日志、添加请求头、身份验证等。

@Component
public class CustomPreFilter implements GatewayFilter, Ordered {private static final Logger logger = LoggerFactory.getLogger(CustomPreFilter.class);@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 获取请求路径String path = exchange.getRequest().getURI().getPath();logger.info("Incoming request: " + path);// 可以在此处添加请求头、检查授权等操作exchange.getRequest().mutate().header("X-Custom-Header", "customValue").build();return chain.filter(exchange);  // 继续过滤链}@Overridepublic int getOrder() {return 0;  // 设置优先级,数字越小越先执行}
}

3.2 后置过滤器(Post Filter)

后置过滤器用于请求经过目标服务处理后,但在返回给客户端之前进行处理。

@Component
public class CustomPostFilter implements GatewayFilter, Ordered {private static final Logger logger = LoggerFactory.getLogger(CustomPostFilter.class);@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {return chain.filter(exchange).then(Mono.fromRunnable(() -> {// 这里可以对响应进行处理logger.info("Response sent with status: " + exchange.getResponse().getStatusCode());}));}@Overridepublic int getOrder() {return 1;  // 设置优先级}
}

3.3 全局过滤器

全局过滤器适用于所有路由,它们可以在路由规则之外做一些全局处理。

@Component
public class GlobalFilterExample implements GlobalFilter, Ordered {private static final Logger logger = LoggerFactory.getLogger(GlobalFilterExample.class);@Overridepublic Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain) {logger.info("Global filter triggered, path: " + exchange.getRequest().getURI().getPath());return chain.filter(exchange);  // 继续过滤链}@Overridepublic int getOrder() {return 0;  // 设置优先级}
}

✅ 4. 负载均衡与服务发现

如果你使用 Eureka,Spring Cloud Gateway 能与 Eureka 无缝集成,自动支持服务发现和负载均衡。

application.yml 配置:

spring:cloud:gateway:routes:- id: route_to_serviceuri: lb://SERVICE_NAME  # lb://SERVICE_NAME 会通过 Eureka 自动查找predicates:- Path=/service/**  # 匹配请求路径
  • lb://:代表负载均衡的服务名称,Spring Cloud Gateway 会自动与 Eureka 进行集成,从而获取注册的服务。
  • 使用 Ribbon 进行负载均衡。

✅ 5. 安全性:OAuth2 与 JWT

Spring Cloud Gateway 也能与 OAuth2JWT 集成,进行请求的认证和授权。

配置示例:

spring:cloud:gateway:routes:- id: secure_routeuri: http://localhost:8081predicates:- Path=/secure/**filters:- name: RequestHeaderToRequestUriargs:name: Authorization

你可以通过 Spring SecurityOAuth2 集成,对请求进行授权认证。


✅ 6. 测试和监控

Spring Cloud Gateway 还内建了监控与健康检查功能,集成了 Spring Boot Actuator

配置 Actuator:

management:endpoints:web:exposure:include: health,metrics,gateway

通过 /actuator/gateway/routes 可以查看当前网关的路由状态和信息。


✅ 总结:

Spring Cloud Gateway 是一个高性能的 API 网关,它的优点包括:

  • 与 Spring 生态无缝集成:非常适合 Spring Boot 和 Spring Cloud 项目。
  • 强大的路由和过滤功能:支持动态路由、限流、日志记录等功能。
  • 支持负载均衡和服务发现:与 Eureka、Consul 集成,支持服务发现。
  • 灵活的过滤器支持:自定义前置、后置过滤器以及全局过滤器。

如果你的项目使用 Spring Cloud 架构,Spring Cloud Gateway 是首选的 API 网关解决方案。


版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词