Gateway路由

有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top

全网最细面试题手册,支持艾宾浩斯记忆法。这是一份最全面、最详细、最高质量的 java面试题,不建议你死记硬背,只要每天复习一遍,有个大概印象就行了。 https://store.amazingmemo.com/chapterDetail/1685324709017001`

Gateway路由配置分为基于配置的静态路由设置和基于代码动态路由配置,

静态路由是指在application.yml中把路由信息配置好了,而动态路由则支持在代码中动态加载路由信息,更加灵活,我们接下来把这2种路由操作都实现一次。

2.2.1 业务说明

如上图:

  1. 用户所有请求以/order开始的请求,都路由到 hailtaxi-order服务

  2. 用户所有请求以/driver开始的请求,都路由到 hailtaxi-driver服务

  3. 用户所有请求以/pay开始的请求,都路由到 hailtaxi-pay服务

基于配置路由设置

  1. 用户所有请求以/order开始的请求,都路由到 hailtaxi-order服务

  2. 用户所有请求以/driver开始的请求,都路由到 hailtaxi-driver服务

  3. 用户所有请求以/pay开始的请求,都路由到 hailtaxi-pay服务 配置参数说明:

routes:路由配置

- id:唯一标识符

uri:路由地址,可以是 lb://IP:端口     也可以是   lb://${spring.application.name}

predicates:断言,是指路由条件

- Path=/driver/**:路由条件。Predicate 接受一个输入参数,返回一个布尔值结果。这里表示匹配所有以driver开始的请求。

filters:过滤器

- StripPrefix=1:真实路由的时候,去掉第1个路径,路径个数以/分割区分

基于代码路由配置

我们同样实现上面的功能,但这里基于代码方式实现。所有路由规则我们可以从数据库中读取并加载到程序中。基于代码的路由配置我们只需要创建RouteLocator并添加路由配置即可,代码如下:

/***

 * 路由配置

 * @param builder

 * @return

 */

@Bean

public RouteLocator routeLocator(RouteLocatorBuilder builder) {

    return builder.routes()

        .route("hailtaxi-driver", r -> r.path("/driver/**").uri("lb://hailtaxi-driver"))

        .route("hailtaxi-order", r -> r.path("/order/**").uri("lb://hailtaxi-order"))

        .route("hailtaxi-pay", r -> r.path("/pay/**").uri("lb://hailtaxi-pay"))

        .build();

}

在真实场景中,基于配置文件的方式更直观、简介,但代码的路由配置是更强大,可以实现很丰富的功能,可以把路由规则存在数据库中,每次直接从数据库中加载规则,这样的好处是可以动态刷新路由规则,通常应用于权限系统动态配置。

spring: 

    cloud: 

        gateway:

          #路由配置

          routes:

            #唯一标识符

            - id: hailtaxi-driver

              uri: lb://hailtaxi-driver

              #路由断言

              predicates:

                - Path=/driver/**

            #唯一标识符

            - id: hailtaxi-order

              uri: lb://hailtaxi-order

              #路由断言

              predicates:

                - Path=/order/**

            #唯一标识符

            - id: hailtaxi-pay

              uri: lb://hailtaxi-pay

              #路由断言

              predicates:

                - Path=/pay/**

最后更新于