java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringCloud Gateway路由配置

SpringCloud Gateway路由表配置实现小结

作者:南屿欣风

SpringCloudGateway通过路由表将请求转发到不同的服务或地址,每个路由包含id、uri、predicates和filters等字段,下面就来介绍一下SpringCloud Gateway路由如何配置,感兴趣的可以了解一下

Spring Cloud Gateway 的路由表是网关的核心配置,负责将请求转发到不同的服务 / 地址。以下是基于示例配置的关键解析:

一、基础结构

路由表配置在spring.cloud.gateway.routes下,每个路由是一个独立的配置项,包含以下核心字段:

spring:
  cloud:
    gateway:
      routes:
        - id: 路由唯一标识  # 每个路由必须有唯一id
          uri: 目标地址       # 请求要转发到的地址
          predicates: []      # 路由匹配规则(满足条件才转发)
          filters: []         # 路由过滤器(转发前后的加工逻辑)
          order: 优先级数字   # 数字越小,优先级越高

二、示例配置拆解

以示例中的两个路由为例,解析不同场景的配置逻辑:

1. 转发到外部地址(bing-route)

- id: bing-route  # 路由id:bing-route
  uri: https://cn.bing.com/  # 目标地址:必应官网(外部地址)
  predicates:
    - Path=/**  # 匹配规则:所有路径(任意请求都能匹配)
  filters: []   # 无过滤器
  order: 10     # 优先级:10(数字大,优先级低)
  metadata:     # 自定义元数据(非核心,可用于扩展逻辑)
    hello: world

2. 转发到微服务(order-route)

- id: order-route  # 路由id:order-route
  uri: lb://service-order  # 目标地址:微服务service-order(lb=负载均衡)
  predicates:
    - Path=/api/order/**  # 匹配规则:以/api/order/开头的路径
  order: 1  # 优先级:1(数字小,优先级高)

三、核心字段说明

字段名

作用

id

路由唯一标识,不能重复

uri

转发目标:- 外部地址:https://xxx.com

- 微服务:lb://服务名

predicates

路由匹配规则(多个规则需同时满足),常用Path=/xxx/**

(路径匹配)

filters

过滤器(如添加请求头、路径重写等),空数组表示无过滤

order

路由优先级:数字越小,优先级越高(多个路由匹配时,优先走 order 小的)

四、优先级注意事项

示例中order-route的order=1,bing-route的order=10:

到此这篇关于SpringCloud Gateway路由表配置实现小结的文章就介绍到这了,更多相关SpringCloud Gateway路由配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文