点击上方“ 陶陶技术笔记 ”关注我
回复“ 资料 ”获取作者整理的大量学习资料!
网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍 Spring Cloud Gateway
实现的思路,并且以 Nacos
为数据源来讲解
PS :关于 Spring Cloud Zuul
的动态路由请看文章《 Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单 》
要实现动态路由只需关注下面4个点
网关启动时, 动态路由
的数据怎样加载进来
静态路由
与 动态路由
以那个为准,ps: 静态路由
指的是配置文件里写死的路由配置
监听 动态路由
的数据源变化
数据有变化时怎样 通知gateway
刷新路由
Spring Cloud Gateway
中加载路由信息分别由以下几个类负责
PropertiesRouteDefinitionLocator :从配置文件中读取路由信息(如YML、Properties等)
RouteDefinitionRepository :从存储器中读取路由信息(如内存、配置中心、Redis、MySQL等)
DiscoveryClientRouteDefinitionLocator :从注册中心中读取路由信息(如Nacos、Eurka、Zookeeper等)
我们可以通过自定义 RouteDefinitionRepository
的实现类来实现动态路由的目的
创建一个 Nacos
的 RouteDefinitionRepository
实现类
NacosRouteDefinitionRepository
重写 getRouteDefinitions
方法实现路由信息的读取
配置Nacos监听器,监听路由配置信息的变化
路由变化只需要往 ApplicationEventPublisher
推送一个 RefreshRoutesEvent
事件即 可 ,gateway会自动监听该事件并调用 getRouteDefinitions
方法更新路由信息
DynamicRouteConfig
Nacos
路由配置 新增配置项:
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
端点查看当前路由信息
可以看到 Nacos
里配置的两条路由信息
完整的Spring Cloud Gateway代码请查看
https://gitee.com/zlt2000/microservices-platform/tree/master/zlt-gateway/sc-gateway
往期 精彩 回顾
日志排查问题困难?分布式日志链路跟踪来帮你
限流怎么做?网关zuul集成Sentinel最新的网关流控组件
阿里注册中心Nacos生产部署方案
Spring Cloud开发人员如何解决服务冲突和实例乱窜?
Spring Cloud同步场景分布式事务怎样做?试试Seata
Spring Cloud异步场景分布式事务怎样做?试试RocketMQ
我就知道你“在看”