网关的核心概念就是路由配置和路由规则,而做为全部请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽可能要避免重启的,因此实现动态路由是很是有必要的;本文主要介绍 Spring Cloud Gateway
实现的思路,而且以Nacos
为数据源来说解java
PS:关于 Spring Cloud Zuul
的动态路由请看文章《Spring Cloud Zuul的动态路由怎样作?集成Nacos实现很简单》git
要实现动态路由只需关注下面4个点github
动态路由
的数据怎样加载进来静态路由
与动态路由
以那个为准,ps:静态路由
指的是配置文件里写死的路由配置动态路由
的数据源变化通知gateway
刷新路由
Spring Cloud Gateway
中加载路由信息分别由如下几个类负责json
咱们能够经过自定义 RouteDefinitionRepository
的实现类来实现动态路由的目的异步
建立一个Nacos
的RouteDefinitionRepository
实现类分布式
NacosRouteDefinitionRepository类可查看:NacosRouteDefinitionRepository.java 测试
重写
getRouteDefinitions
方法实现路由信息的读取spa
配置Nacos监听器,监听路由配置信息的变化 .net
路由变化只须要往
ApplicationEventPublisher
推送一个RefreshRoutesEvent
事件即刻,gateway会自动监听该事件并调用getRouteDefinitions
方法更新路由信息日志
DynamicRouteConfig类可查看:DynamicRouteConfig.java
Nacos
路由配置[
{
"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代码请查看
推荐阅读
扫码关注有惊喜!