springcloud gateway动态路由

动态每秒调用数据库,加载路由信息到路由定义(RouteDefinition)中

主要是继承 RouteDefinitionRepository接口:

如果项目没有自定义的RouteDefinitionRepository 则会加载InMemoryRouteDefinitionRepository

默认将加载的规则存放在内存,加载application.properties文件中配置的路由规则,InMemory加载内存中配置的路由规则

Application启动的时候内存中是没有路由规则的且Application关闭的时候内存中保存的路由规则也会丢失

我们可以通过自定义RouteDefinitionRepository类替换掉InMemoryRouteDefinitionRepository

实现将路由规则保存到数据库中

java 复制代码
@Component
@Slf4j
public class DbRouteDefinitionRepository implements RouteDefinitionRepository {

    @Resource
    private SysRouteConfMapper sys;


    @Override
    public Flux<RouteDefinition> getRouteDefinitions() {
        List<RouteDefinition> routeDefinitions = new ArrayList<>();
//获取数据库路由信息
        List<SysRouteConf> gatewayRouteList = sysRouteConfMapper.selectList();
//路由信息转为路由定义
        gatewayRouteList.forEach(gatewayRoute -> {
            RouteDefinition routeDefinition = JSONObject.parseObject(gatewayRoute.toString(), RouteDefinition.class);
            routeDefinitions.add(routeDefinition);
        });
//存入内存中
        return Flux.fromIterable(routeDefinitions);
    }

    @Override
    public Mono<Void> save(Mono<RouteDefinition> route) {
        return null;
    }

    @Override
    public Mono<Void> delete(Mono<String> routeId) {
        return null;
    }
}
获取请求的路由信息

主要从RouteLocator的三个实现类中获取

//获取路径

java 复制代码
    protected String getUrl() {
        AtomicReference<String> url = new AtomicReference<>("");
        RouteLocator cachedCompositeRouteLocator = SpringUtils.getBean("cachedCompositeRouteLocator");
        Flux<Route> identification = cachedCompositeRouteLocator.getRoutes().filter(route -> {
            return route.getId().equals("identification");
        });
        identification.subscribe(result -> {
            URI uri = result.getUri();
            if (uri != null && ("lb".equals(uri.getScheme()))) {
                ServiceInstance router = loadBalancer.choose("identification");
                url.set(router.getHost() + ":" + router.getPort());
            }
            if (uri != null && ("http".equals(uri.getScheme()) || "https".equals(uri.getScheme()))) {
                url.set(uri.getHost() + ":" + uri.getPort());
            }
        });
        return url.get();
    }

相关流程见此链接:

【Spring Cloud】Gateway ------ RouteLocator RouteDefinitionLocator FilteringWebHandler_spring gateway filteringwebhandler-CSDN博客

相关推荐
Albert Edison4 小时前
【最新版】IntelliJ IDEA 2025 创建 SpringBoot 项目
java·spring boot·intellij-idea
六毛的毛7 小时前
Springboot开发常见注解一览
java·spring boot·后端
开开心心就好9 小时前
免费PDF处理软件,支持多种操作
运维·服务器·前端·spring boot·智能手机·pdf·电脑
猴哥源码9 小时前
基于Java+SpringBoot的农事管理系统
java·spring boot
光军oi10 小时前
java微服务(Springboot篇)——————IDEA搭建第一个Springboot入门项目
java·spring boot·微服务
guojl12 小时前
RestTemplate使用手册
spring cloud·微服务
guojl12 小时前
RestTemplate原理分析
spring cloud·微服务
猴哥源码12 小时前
基于Java+SpringBoot的健身房管理系统
java·spring boot
猴哥源码12 小时前
基于Java+SpringBoot的三国之家网站
java·spring boot
Ken_111512 小时前
SpringCloud系列(51)--SpringCloud Stream之使用分组解决消息重复消费问题
spring cloud