Spring Cloud Gateway的动态路由怎样做?集成Nacos实现很简单
2019-10-21 15:07
721 查看
原文链接:https://www.geek-share.com/detail/2782634480.html
3.3. 添加
一、说明
叮当 wap.guxs.net网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍
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
扫码关注有惊喜!
相关文章推荐
- Spring Cloud Gateway的动态路由怎样做?集成Nacos实现很简单
- Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单
- Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单
- SpringCloud Zuul实现动态路由
- SpringCloud教程十:Zuul+Mysql实现动态路由
- Spring Cloud 系列之 Spring cloud gateway 实现网关路由转发和过滤功能
- Spring Cloud Zuul实现动态路由(zuul设计)
- 利用Spring Cloud Zuul实现动态路由示例代码
- springcloud gateway实现路由和负载均衡
- 使用Spring Cloud Zuul实现动态路由
- 基于Redis实现Spring Cloud Gateway的动态管理
- spring cloud gateway 实现接口限流
- springboot 2.0.0.RELEASE +spring cloud Finchley.M7 +springcloud bus+kafka实现配置动态刷新
- Spring Cloud Config + Spring Cloud Bus 实现配置文件动态刷新(版本 Finchley.RC1)
- spring cloud gateway 限流的实现与原理
- spring cloud gateway 限流的实现与原理
- 【MS】springcloud-gateway 中实现服务之间鉴权,只能从网关访问,禁止直接访问服务
- SpringCloud微服务架构搭建(四):动态路由
- 详解Spring Cloud Gateway基于服务发现的默认路由规则
- Spring Cloud体系实现标签路由的方法示例