Spring Cloud gateway 路由规则

Spring Cloud gateway 路由规则

文章目录

一、路由常用属性解析

1.1 示例配置
server:
  port: 90
spring:
  cloud:
    gateway:
      discovery:
        locator:
          enabled: true #启动DiscoveryClient,可以实现服务的发现,自动根据注册的服务创建对应的路由
      routes:
        - id: Auth
          uri: lb://wuxsms-auth
          order: -1
          predicates:
            - Path=/wuxsms-auth/**
          filters:
            - RewritePath=/wuxsms-auth/(?<segment>.*), /${segment}
            - StripPrefix=2
1.2 属性解析
  1. id

    1. 类型:字符串
    2. 作用:唯一标识一个路由。必须是唯一的,不能重复。
    3. 示例:
  2. uri

    1. 类型:字符串
    2. 作用:指定目标微服务的 URI。可以是具体的 URL(http://www.baidu.com等第三方系统),也可以配合nacos服务注册中心负载均衡的 URI(如 lb://service-name)。
  3. predicates

    1. 类型:列表

    2. 作用:定义一组断言,用于决定请求是否匹配该路由。每个断言都是一个条件,所有条件都满足时,请求才会被路由到目标微服务。

    3. 常见断言:

      • Path:匹配请求路径。
      • Method:匹配请求方法(GET、POST 等)。
      • Query:匹配查询参数。
      • Header:匹配请求头。
      • Cookie:匹配请求中的 Cookie。
      • Host:匹配请求主机。
    4. 匹配规则

    5. 匹配规则

      语法

      示例

      解释

      精确匹配

      Path=/exact/path

      Path=/api/user

      匹配请求路径为 /api/user 的请求

      单级通配符

      Path=/path/*

      Path=/api/user/*

      匹配 /api/user/ 下的一级子路径,例如 /api/user/profile

      多级通配符

      Path=/path/**

      Path=/api/user/**

      匹配 /api/user/ 下的所有子路径,包括多级子路径,例如 /api/user/profile 和 /api/user/orders/123

      正则表达式

      Path=/pattern

      Path=/api/user/d+

      匹配 /api/user/ 后跟一个或多个数字的路径,例如 /api/user/123

  4. filters

    1. 类型:列表

    2. 作用:定义一组过滤器,用于在请求转发前后对请求或响应进行修改。过滤器可以改变请求路径、添加请求头等。

    3. 常见过滤器:

      • StripPrefix:去掉路径前缀。

        • StripPrefix 过滤器可以用来去掉路径中的前缀部分。这个过滤器更简单,适合去掉固定数量的路径段。

          例如:

          spring:
            cloud:
              gateway:
                routes:
                  - id: user-service
                    uri: lb://user-service
                    predicates:
                      - Path=/api/user/**
                    filters:
                      - StripPrefix=2
          

          在这个配置中:

          • Path=/api/user/** 表示匹配以 /api/user/ 开头的路径。
          • StripPrefix=2 表示去掉路径中的前两个段,即 /apiuser
      • RewritePath:重写请求路径。

      • springCloud 中网关自动转发到其他服务就是使用改属性的配置

      • AddResponseHeader:添加响应头。

      • SetStatus:设置响应状态码。

      • Retry:重试机制。

  5. order

    1. 类型:整数
    2. 作用:定义路由的优先级。顺序值越小,优先级越高。默认情况下,路由是按配置顺序依次匹配的,只要匹配到就不再往下匹配。
  6. metadata

    1. 类型:键值对
    2. 作用:存储额外的元数据信息,可以在过滤器或其他组件中使用。

二、问题分析,springCloud微服务中没有任何路由配置,网关为什么能根据请求转发到相应的业务服务的

2.1 开启,用于启用通过服务发现来路由到服务的功能
spring:
  cloud:
    gateway:
      discovery:
        locator:
          enabled: true
2.2 断点RoutePredicateHandlerMapping类查看自动注册的路由

在这里插入图片描述

发现有两条【lb://wuxsms-auth】服务的路由配置

在这里插入图片描述

为什么会有两条呢?

  1. 第一条:nacos配置中心自定义配置的一条
  2. 第二条:配置【spring: cloud: gateway: discovery: locator: enabled: true】是自动创建的一条

第一条:

在这里插入图片描述

第二条:

在这里插入图片描述

2.3 自动创建注册到Nacos的路由配置,包括dubbo服务
onNext(Route{id='ReactiveCompositeDiscoveryClient_wuxsms-auth', uri=lb://wuxsms-auth, order=0, predicate=Paths: [/wuxsms-auth/**], match trailing slash: true, gatewayFilters=[[[RewritePath /wuxsms-auth/(?<remaining>.*) = '/${remaining}'], order = 1]], metadata={nacos.instanceId=192.168.1.111#8889#DEFAULT#DEFAULT_GROUP@@wuxsms-auth, nacos.weight=1.0, nacos.cluster=DEFAULT, nacos.healthy=true, dubbo.metadata-service.urls=[ "dubbo://192.168.1.111:20880/com.alibaba.cloud.dubbo.service.DubboMetadataService?anyhost=true&application=wuxsms-auth&bind.ip=192.168.1.111&bind.port=20880&deprecated=false&dubbo=2.0.2&dynamic=true&generic=false&group=wuxsms-auth&interface=com.alibaba.cloud.dubbo.service.DubboMetadataService&methods=getAllServiceKeys,getServiceRestMetadata,getExportedURLs,getAllExportedURLs&pid=1540&qos.enable=false&release=2.7.4.1&revision=2.2.0.RELEASE&side=provider&threads=500&timeout=6000&timestamp=1731655720770&version=1.0.0" ], preserved.register.source=SPRING_CLOUD}})
  1. predicate: /wuxsms-auth/**,配置服务名称开头的路由
  2. RewritePath : /wuxsms-auth/(.*), /${segment} 去掉服务前缀后再转发到相应的服务
  3. order:0 ,小于nacos配置中心的优先级
  4. match trailing slash:true 匹配尾部斜杠
  5. Metadata: 元数据 (存储额外的元数据信息,可以在过滤器或其他组件中使用)
2.4 未开启 【spring: cloud: gateway: discovery: locator: enabled: false】

在这里插入图片描述

不开启该配置,则需要手动配置路由规则。若两者都没有配置则系统无法正常访问

### Spring Cloud Gateway 跆由规则配置示例与教程 Spring Cloud Gateway 是一个基于 Spring 5 和 Project Reactor 的 API 网关,它提供了强大的路由和过滤功能。以下是关于 Spring Cloud Gateway 路由规则配置的相关信息和示例。 #### 1. 路由规则的基本组成 路由是网关的基本单元,由以下部分组成[^1]: - **ID**:路由的唯一标识符。 - **URI**:目标服务的地址,可以是 HTTP URI 或者服务发现中的服务名。 - **Predicate(断言)**:用于匹配请求的条件,例如路径、查询参数、方法等。 - **Filter(过滤器)**:在请求或响应过程中执行特定逻辑的组件。 #### 2. 示例配置 以下是一个典型的 Spring Cloud Gateway 配置示例: ```yaml server: port: 8080 spring: cloud: gateway: routes: - id: service1_route uri: http://localhost:8081 predicates: - Path=/service1/** filters: - AddRequestHeader=Service1-Header, Service1-Value - id: service2_route uri: http://localhost:8082 predicates: - Path=/service2/** - Method=GET filters: - StripPrefix=1 ``` #### 3. 常见 Predicate 类型 Spring Cloud Gateway 提供了多种内置的 Predicate 工厂,常见的有以下几种: - **Path**:根据请求路径进行匹配。 ```yaml predicates: - Path=/api/v1/** ``` - **Query**:根据查询参数进行匹配。 ```yaml predicates: - Query=name ``` - **Method**:根据 HTTP 方法进行匹配。 ```yaml predicates: - Method=POST ``` - **Before/After**:根据时间戳进行匹配。 ```yaml predicates: - Before=2023-01-01T00:00:00+08:00[Asia/Shanghai] ``` #### 4. 动态路由配置 如果未显式配置路由规则Spring Cloud Gateway 可以通过服务发现机制自动注册路由[^2]。启用此功能需要在配置文件中添加以下内容: ```yaml spring: cloud: gateway: discovery: locator: enabled: true ``` 当此功能启用后,Gateway 会自动将服务发现中的服务注册为路由,并通过 `RoutePredicateHandlerMapping` 类完成动态路由的创建[^2]。 #### 5. 过滤器配置 过滤器用于修改请求或响应的内容。以下是一些常用的过滤器配置示例: - **AddRequestHeader**:为请求添加头部信息。 ```yaml filters: - AddRequestHeader=X-Request-ID, 123456 ``` - **StripPrefix**:移除指定数量的路径前缀。 ```yaml filters: - StripPrefix=1 ``` #### 6. 时间条件下的路由配置 可以通过 `Before` 和 `After` 断言来限制路由的有效时间段。例如,以下配置表示在指定时间之前允许路由[^3]: ```yaml spring: cloud: gateway: routes: - id: time_sensitive_route uri: http://localhost:8081 predicates: - Path=/time-sensitive - Before=2023-12-31T23:59:59+08:00[Asia/Shanghai] ``` #### 7. Path 匹配规则 `Path` 断言可以根据请求路径进行匹配。例如,以下配置表示匹配 `/payment/{segment}` 的路径[^4]: ```yaml spring: cloud: gateway: routes: - id: payment_route uri: https://www.baidu.com predicates: - Path=/payment/{segment} ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值