一、说明
网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍
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
的实现类来实现动态路由的目的
3.1. 实现动态路由的数据加载
创建一个
Nacos
的
RouteDefinitionRepository
实现类
NacosRouteDefinitionRepository类可查看:
NacosRouteDefinitionRepository.java 重写 getRouteDefinitions
方法实现路由信息的读取
配置Nacos监听器,监听路由配置信息的变化
路由变化只需要往推送一个
ApplicationEventPublisher
事件即刻,gateway会自动监听该事件并调用
RefreshRoutesEvent
方法更新路由信息
getRouteDefinitions
3.2. 创建配置类
DynamicRouteConfig类可查看:
DynamicRouteConfig.java 3.3. 添加 Nacos
路由配置
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推荐阅读