微服务网关全解析:从入门到实践

引言

在微服务架构中,服务数量众多,调用关系复杂。如果没有一个统一的入口来进行流量调度、权限控制和安全管理,系统的可维护性和安全性都会大大降低。Spring Cloud Gateway 作为新一代网关组件,基于 Spring 5、Spring Boot 2.0 和 Project Reactor 的响应式编程模型,为我们提供了一种高性能、统一的 API 路由与管理方式。

本文将从 为什么需要网关快速入门断言与过滤器机制同源策略与跨域问题 等方面进行系统性梳理,帮助读者快速掌握 Gateway 的核心思想与实践技巧。


一、为什么需要网关

在微服务系统中,网关扮演着"守门人"的角色,所有外部请求都会先进入网关,然后再根据规则路由到对应的服务。它的核心价值主要体现在以下几个方面:

  1. 统一入口

    • 外部访问全部先经过 Gateway,便于集中管理和监控。
  2. 请求路由与负载均衡

    • 根据配置的规则转发请求,并在多实例时进行负载均衡。
  3. 权限控制

    • 拦截请求,校验用户是否有访问权限,防止非法访问。
  4. 限流保护

    • 在流量过大时按下游服务的承受能力进行流控,避免雪崩效应。

Spring Cloud Gateway 相比传统的 Zuul,采用响应式编程(WebFlux),性能更高,延迟更低,尤其适合高并发场景。


二、快速入门 Gateway

2.1 创建工程与依赖引入

在 pom.xml 中添加以下依赖:

XML 复制代码
<!-- Gateway 网关核心依赖 -->
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!-- Nacos 服务发现 -->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

2.2 配置路由规则

在 application.yml 中定义路由规则:

复制代码
server:
  port: 7000
spring:
  application:
    name: api-gateway
  cloud:
    gateway:
      routes:
        - id: product_route
          uri: http://localhost:8081/
          predicates:
            - Path=/product-serv/**
          filters:
            - StripPrefix=1

此时,访问 http://localhost:7000/product-serv/product/19 会被代理到 http://localhost:8081/product/19。

2.3 高级版本:结合 Nacos 服务发现

通过 lb:// 方式实现负载均衡:

复制代码
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
    gateway:
      discovery:
        locator:
          enabled: true
      routes:
        - id: product_route
          uri: lb://service-product
          predicates:
            - Path=/product-serv/**

这样,网关会自动从 Nacos 获取服务实例并按策略进行负载均衡。


三、断言工厂(Predicate Factory)

断言(Predicate)决定了请求是否满足路由条件。Spring Cloud Gateway 提供了十几种常见的断言类型:

  • Path:请求路径匹配

    • Path=/user/**
  • Method:请求方法限制

    • Method=GET,POST
  • Header:请求头条件

    • Header=X-Request-Id, \d+
  • After/Before/Between:时间范围限制

  • CookieHostQueryRemoteAddr

这些断言通过工厂类(如 PathRoutePredicateFactory)转换为路由条件,实现灵活的流量分发。


四、过滤器工厂(Filter Factory)

4.1 路由过滤器

对特定路由生效,例如:

复制代码
filters:
  - AddRequestHeader=msg, hello

4.2 默认过滤器(DefaultFilter)

对所有路由生效:

复制代码
default-filters:
  - AddRequestHeader=msg, wake up!

4.3 全局过滤器(GlobalFilter)

需要自定义逻辑,例如权限校验、限流等。

示例:拦截请求,校验 authorization=admin,否则拒绝访问。

java 复制代码
@Order(-1)
@Component
public class AuthorizeFilter implements GlobalFilter {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String auth = exchange.getRequest().getQueryParams().getFirst("authorization");
        if ("admin".equals(auth)) {
            return chain.filter(exchange);
        }
        exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
        return exchange.getResponse().setComplete();
    }
}

4.4 执行顺序

  • 优先级规则:order 值越小,执行越靠前。

  • 同 order 时,执行顺序为:DefaultFilter > 路由过滤器 > GlobalFilter。


五、浏览器同源策略与跨域问题

浏览器的 同源策略 要求协议、域名和端口一致,否则会被视为跨域请求。

例如:

跨域会导致 AJAX 请求被拦截。解决方案是开启 CORS(跨源资源共享)

Gateway 配置 CORS

复制代码
spring:
  cloud:
    gateway:
      globalcors:
        add-to-simple-url-handler-mapping: true
        corsConfigurations:
          '[/**]':
            allowedOrigins: "http://localhost:8090"
            allowedMethods: [ "GET", "POST", "DELETE", "PUT", "OPTIONS" ]
            allowedHeaders: "*"
            allowCredentials: true
            maxAge: 360000

这样就可以允许前端跨域请求,避免浏览器拦截。


六、总结

Spring Cloud Gateway 为微服务提供了一个 统一的请求入口 ,通过 断言与过滤器机制 实现灵活的路由控制、权限校验和流量治理。同时,内置的 CORS 配置 也帮助我们轻松解决前后端分离下的跨域问题。

整体而言,Gateway 是微服务架构中不可或缺的组件。掌握它的配置与原理,将大大提升系统的稳定性与可维护性。

相关推荐
纪莫2 小时前
技术面:Spring (bean的生命周期、创建方式、注入方式、作用域)
java·spring·java面试⑧股
slandarer2 小时前
MATLAB | 这是屎吗?抱歉打错了,这是什么?
开发语言·matlab
We....2 小时前
Java多线程分块下载文件
java·开发语言
不秃的开发媛2 小时前
Java连接池详解:从Oracle到TiDB的随缘之旅
java·oracle·tidb
Pluchon3 小时前
硅基计划3.0 Map类&Set类
java·开发语言·数据结构·算法·哈希算法·散列表
Angelyb3 小时前
微服务保护和分布式事务
java·微服务·架构
鼠鼠我捏,要死了捏3 小时前
蓝绿发布与滚动更新:基于Kubernetes的微服务零停机切换实战指南
微服务·kubernetes·blue-green
42fourtytoo3 小时前
天津大学智算2026预推免机试第二批题目及代码c++
开发语言·c++·面试
七夜zippoe3 小时前
缓存三大劫攻防战:穿透、击穿、雪崩的Java实战防御体系(一)
java·开发语言·缓存