一、说明
网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍 spring cloud gateway 实现的思路,并且以nacos为数据源来讲解
二、实现要点
要实现动态路由只需关注下面4个点
网关启动时,动态路由的数据怎样加载进来
静态路由与动态路由以那个为准,ps:静态路由指的是配置文件里写死的路由配置
监听动态路由的数据源变化
数据有变化时怎样通知gateway刷新路由
三、具体实现
spring cloud gateway 中加载路由信息分别由以下几个类负责
propertiesroutedefinitionlocator:从配置文件中读取路由信息(如yml、properties等)
routedefinitionrepository:从存储器中读取路由信息(如内存、配置中心、redis、mysql等)
discoveryclientroutedefinitionlocator:从注册中心中读取路由信息(如nacos、eurka、zookeeper等)
我们可以通过自定义 routedefinitionrepository 的实现类来实现动态路由的目的
3.1. 实现动态路由的数据加载
创建一个nacos的routedefiniti