微服务核心组件:Gateway

1. 作用

API Gateway,它作为所有外部请求的唯一入口,承担统一路由、安全鉴权、流量限流、监控埋点等横切职责,是微服务架构的 "门面" 与 "流量中枢"。由于微服务的应用可能部署在不同的地方,此时有了网关,客户端相关的请求直接发送到网关,由网关根据请求标识解析判断出具体的微服务地址,再把请求转发到微服务实例。

2. 核心工作原理与流程

Gateway 的请求处理流程可概括为 "接收→匹配→过滤→转发→响应",核心依赖三大组件:

核心组件 作用 关键说明
路由 (Route) 网关的基本单元 包含 ID、目标 URI、断言集合、过滤器集合,定义请求转发规则
断言(Predicate) 路由匹配规则 基于 HTTP 请求的路径、请求头、方法、时间等条件判断是否匹配路由
过滤器 (Filter) 请求 / 响应处理 分为全局过滤器 (所有请求生效)和局部过滤器(指定路由生效),可在请求前(Pre)或响应后(Post)执行逻辑

完整请求流程:客户端请求 → Netty 接收 → 路由断言匹配 → 过滤器链执行(Pre) → 转发至目标微服务 → 过滤器链执行(Post) → 响应返回客户端。

spring cloud gateway中配置uri有三种方式,包括

  • websocket配置方式
bash 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: ruoyi-api
          uri: ws://localhost:9090/
          predicates:
            - Path=/api/**
  • http地址配置方式
bash 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: ruoyi-api
          uri: http://localhost:9090/
          predicates:
  • 注册中心配置方式
bash 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: ruoyi-api
          uri: lb://ruoyi-api
          predicates:
            - Path=/api/**

3. 示例

bash 复制代码
spring:
  cloud:
    gateway:
      # 动态路由:从 Nacos 注册中心获取服务列表
      discovery:
        locator:
          enabled: true # 开启服务发现路由
      # 自定义路由规则
      routes:
        - id: system-service-route
          uri: lb://ruoyi-system # 指向 Nacos 中的系统服务
          predicates:
            - Path=/system/** # 匹配 /system 开头的请求
          filters:
            - StripPrefix=1 # 去除路径前缀(将 /system/user 转为 /user)
            - name: RequestRateLimiter # 限流过滤器
              args:
                redis-rate-limiter.replenishRate: 10 # 每秒生成令牌数
                redis-rate-limiter.burstCapacity: 20 # 令牌桶容量
相关推荐
唐青枫18 分钟前
Java Future 与 CompletableFuture 实战指南:从异步结果到任务编排
java
长孙豪翔26 分钟前
在.net中读写config文件的各种方法
java·数据库·.net
tachibana227 分钟前
hot100 回文链表(234)
java·网络·数据结构·leetcode·链表
可乐ea33 分钟前
【Java八股|第10篇】Java 中的包装类和自动拆装箱
java·面试题·包装类·java八股
zfoo-framework44 分钟前
mongo最佳实战(from mongo中文社区)
java
深盾科技_Virbox1 小时前
加密狗授权能力选型:从授权模型到全生命周期管理
java·网络·数据库
. . . . .2 小时前
Egg框架深入
java·开发语言
RainCity2 小时前
Java Swing 自定义组件库分享(十三)
java·笔记·后端
livemetee3 小时前
【关于Spring声明式事务】
java·后端·spring
倒流时光三十年3 小时前
Java 内存模型(JMM)通俗解释
java·开发语言