Spring Cloud Gateway的动态路由怎样作?集成Nacos实现很简单

file

1、说明

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

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

 

2、实现要点

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

  1. 网关启动时,动态路由的数据怎样加载进来
  2. 静态路由动态路由以那个为准,ps:静态路由指的是配置文件里写死的路由配置
  3. 监听动态路由的数据源变化
  4. 数据有变化时怎样通知gateway刷新路由

 

3、具体实现

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

  1. PropertiesRouteDefinitionLocator:从配置文件中读取路由信息(如YML、Properties等)
  2. RouteDefinitionRepository:从存储器中读取路由信息(如内存、配置中心、Redis、MySQL等)
  3. DiscoveryClientRouteDefinitionLocator:从注册中心中读取路由信息(如Nacos、Eurka、Zookeeper等)

  咱们能够经过自定义 RouteDefinitionRepository 的实现类来实现动态路由的目的异步

 

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

建立一个NacosRouteDefinitionRepository实现类分布式

NacosRouteDefinitionRepository类可查看:NacosRouteDefinitionRepository.java 测试

file

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

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

file

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

 

3.2. 建立配置类

DynamicRouteConfig类可查看:DynamicRouteConfig.java

file

 

3.3. 添加Nacos路由配置

file
新增配置项:

  • 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": []
	}
]
复制代码

添加两条路由数据

 

4、测试

启动网关经过 /actuator/gateway/routes 端点查看当前路由信息

file

能够看到 Nacos 里配置的两条路由信息

 

完整的Spring Cloud Gateway代码请查看

gitee.com/zlt2000/mic…

 

推荐阅读

  扫码关注有惊喜!

file
相关文章
相关标签/搜索