美文网首页Spring Cloud
Spring Cloud Gateway的动态路由怎样做?集成N

Spring Cloud Gateway的动态路由怎样做?集成N

作者: IT修真院 | 来源:发表于2020-04-09 20:29 被阅读0次

    作者简介:
    陶陶老师
    10年后端工作经验,
    专注Java、SpringBoot、SpringCloud、分布式系统/微服务、中间件等领域。
    公众号:陶陶技术笔记

    一、说明

    网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍 Spring Cloud Gateway 实现的思路,并且以Nacos为数据源来讲解

    PS:关于 Spring Cloud Zuul 的动态路由请看文章《Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单

    二、实现要点

    要实现动态路由只需关注下面4个点

    1. 网关启动时,动态路由的数据怎样加载进来

    2. 静态路由动态路由以那个为准,ps:静态路由指的是配置文件里写死的路由配置

    3. 监听动态路由的数据源变化

    4. 数据有变化时怎样通知gateway刷新路由

    三、具体实现

    Spring Cloud Gateway 中加载路由信息分别由以下几个类负责

    1. PropertiesRouteDefinitionLocator:从配置文件中读取路由信息(如YML、Properties等)

    2. RouteDefinitionRepository:从存储器中读取路由信息(如内存、配置中心、Redis、MySQL等)

    3. DiscoveryClientRouteDefinitionLocator:从注册中心中读取路由信息(如Nacos、Eurka、Zookeeper等)

    我们可以通过自定义 RouteDefinitionRepository 的实现类来实现动态路由的目的

    3.1. 实现动态路由的数据加载

    创建一个NacosRouteDefinitionRepository实现类

    NacosRouteDefinitionRepository

    ![~V4O]VU$I0VJ5M2WSI}(UQP.png](https://img.haomeiwen.com/i5954723/57161edaabff5943.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    重写 getRouteDefinitions 方法实现路由信息的读取

    配置Nacos监听器,监听路由配置信息的变化

    ![0OG5D5]CXHBDS29@7FU}T22.png](https://img.haomeiwen.com/i5954723/d844411647218a2a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    路由变化只需要往 ApplicationEventPublisher 推送一个 RefreshRoutesEvent 事件即可,gateway会自动监听该事件并调用 getRouteDefinitions 方法更新路由信息

    3.2. 创建配置类
    DynamicRouteConfig

    ![BQV1L]A2K)((5A]U8RJ`51B.png](https://img.haomeiwen.com/i5954723/2c0dca4be54247fa.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    3.3. 添加Nacos路由配置

    ![6MB@{HU1G[MPZK`0Z32)DV.png

    新增配置项:
    Data Id:scg-routes

    Group:SCG_GATEWAY

    配置内容:
    [
    {
    "id": "csdn",
    "predicates": [{
    "name": "Path",
    "args": {
    "pattern": "/csdn/"
    }
    }],
    "uri": "https://www.csdn.net/",
    "filters": []
    },
    {
    "id": "github",
    "predicates": [{
    "name": "Path",
    "args": {
    "pattern": "/github/
    "
    }
    }],
    "uri": "http://github.com/",
    "filters": []
    }
    ]

    添加两条路由数据

    四、测试
    启动网关通过 /actuator/gateway/routes 端点查看当前路由信息

    ![3~ZAI]A6B7V@S_87$CKOM}4.png](https://img.haomeiwen.com/i5954723/88ddf49c4f3dfc27.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    可以看到 Nacos 里配置的两条路由信息

    完整的Spring Cloud Gateway代码请查看

    https://gitee.com/zlt2000/microservices-platform/tree/master/zlt-gateway/sc-gateway

    作者简介:
    陶陶老师
    10年后端工作经验,
    专注Java、SpringBoot、SpringCloud、分布式系统/微服务、中间件等领域。
    公众号:陶陶技术笔记

    本文已经获得陶陶老师授权转发,其他人若有兴趣转载,请直接联系作者授权。

    相关文章

      网友评论

        本文标题:Spring Cloud Gateway的动态路由怎样做?集成N

        本文链接:https://www.haomeiwen.com/subject/wwjhmhtx.html