微服务核心组件: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 # 令牌桶容量
相关推荐
lee_curry7 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣8 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿8 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵9 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
野生技术架构师10 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
空中海11 小时前
第六篇:架构篇 — 微服务、部署、高并发与专家级能力
微服务·云原生·架构
小袁拒绝摆烂11 小时前
多表关联大平层转JSON树形结构
java·json
ja哇12 小时前
大厂面试高频八股
java·面试·职场和发展
yoyo_zzm12 小时前
Laravel6.x新特性全解析
java·spring boot·后端