zuul整合nacos_Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单

本文介绍了如何在Spring Cloud Zuul中实现动态路由,利用Nacos作为数据源加载和更新路由配置。通过重写SimpleRouteLocator,加载静态和动态路由,并创建NacosDynRouteLocator监听Nacos数据变化,当Nacos配置更改时,通过发布事件自动刷新Zuul路由。
摘要由CSDN通过智能技术生成

一、说明

网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的;本文主要介绍实现的思路,并且以Nacos为数据源来讲解

二、实现要点

要实现动态路由只需关注下面4个点网关启动时,动态路由的数据怎样加载进来

静态路由与动态路由以那个为准,ps:静态路由指的是配置文件里写死的路由配置

监听动态路由的数据源变化

数据有变化时怎样通知zuul刷新路由

三、具体实现

3.1. 实现动态路由的数据加载重写SimpleRouteLocator类的locateRoutes方法,此方法是加载路由配置的,父类中是获取properties中的路由配置,可以通过扩展此方法,达到动态获取配置的目的

这里采用静态路由与动态路由共存,相同路由id以动态路由优先覆盖的实现方式

AbstractDynRouteLocator类可查看:AbstractDynRouteLocator.javapublic abstract class AbstractDynRouteLocator extends SimpleRouteLocator implements RefreshableRouteLocator {

private ZuulProperties properties;

public AbstractDynRouteLocator(String servletPath, ZuulProperties properties) {

super(servletPath, properties);

this.properties = properties;

}

/**

* 刷新路由

*/

@Override

public void refresh() {

doRefresh();

}

@Override

protected Map locateRoutes() {

LinkedHashMap routesMap = new LinkedHashMap<>();

// 从application.properties中加载静态路由信息

routesMap.putAll(super.locateRoutes());

// 从数据源中加载动态路由信息

routesMap.putAll(loadDynamicRoute());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值