Spring Cloud Gateway的动态路由怎样做?集成Nac…
2019-10-25 06:43:47来源:博客园 阅读 ()
Spring Cloud Gateway的动态路由怎样做?集成Nacos实现很简单
一、说明
网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍 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
推送一个RefreshRoutesEvent
事件即刻,gateway会自动监听该事件并调用getRouteDefinitions
方法更新路由信息
?
3.2. 创建配置类
DynamicRouteConfig类可查看:DynamicRouteConfig.java
?
3.3. 添加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最新的网关流控组件
- Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单
- Spring Cloud开发人员如何解决服务冲突和实例乱窜?
- Spring Cloud同步场景分布式事务怎样做?试试Seata
- Spring Cloud异步场景分布式事务怎样做?试试RocketMQ
?
扫码关注有惊喜!
原文链接:https://www.cnblogs.com/zlt2000/p/11712943.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- Spring系列.ApplicationContext接口 2020-06-11
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- 给你一份超详细 Spring Boot 知识清单 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 掌握SpringBoot-2.3的容器探针:实战篇 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash