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- 作用:所有请求都会被转发到必应官网;
- 注意:
uri填外部地址时,直接写完整的 HTTP/HTTPS 地址。
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(数字小,优先级高)- 作用:只有路径以
/api/order/开头的请求,才会转发到service-order微服务; - 关键:
uri: lb://服务名是微服务场景的写法,lb表示开启负载均衡(需配合 Nacos/Eureka 等注册中心)。
三、核心字段说明
字段名 | 作用 |
id | 路由唯一标识,不能重复 |
uri | 转发目标:- 外部地址:https://xxx.com - 微服务:lb://服务名 |
predicates | 路由匹配规则(多个规则需同时满足),常用Path=/xxx/** (路径匹配) |
filters | 过滤器(如添加请求头、路径重写等),空数组表示无过滤 |
order | 路由优先级:数字越小,优先级越高(多个路由匹配时,优先走 order 小的) |
四、优先级注意事项
示例中order-route的order=1,bing-route的order=10:
- 当请求路径是/api/order/xxx时,会先匹配order-route(因为优先级更高),转发到service-order;
- 若order-route的order大于bing-route,则/api/order/xxx会被bing-route拦截,转发到必应(不符合预期)。→ 匹配更精确的路由,order要设置更小的数字。
到此这篇关于SpringCloud Gateway路由表配置实现小结的文章就介绍到这了,更多相关SpringCloud Gateway路由配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java仿文库的基本方法(openoffice+swftools+flexPaper)
这篇文章主要为大家详细介绍了Java仿文库的基本方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-02-02
springBoot的事件机制GenericApplicationListener用法解析
这篇文章主要介绍了springBoot的事件机制GenericApplicationListener用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值的相关资料2019-09-09


最新评论