依赖spring-cloud-starter-gateway与spring-cloud-gateway-dependencies的区别


✅ 第一个依赖(spring-cloud-starter-gateway

xml 复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
  • 作用:Spring Cloud Gateway 的启动器(starter),包含运行网关所需的所有核心依赖,如 Netty、路由、过滤器、断言等。
  • 使用场景:在业务项目中引入,用于启动和运行网关服务。

✅ 第二个依赖(spring-cloud-gateway-dependencies

xml 复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-gateway-dependencies</artifactId>
    <version>xxx</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>
  • 作用:Spring Cloud Gateway 的依赖管理(BOM,Bill of Materials),用于统一管理项目中所有 Spring Cloud Gateway 相关依赖的版本号。
  • 使用场景 :通常用于父项目的 <dependencyManagement> 中,帮助子模块统一版本,不包含具体代码,不能直接运行网关功能。

举个例子说明区别

假设你有一个父工程,多个子模块都要用 Spring Cloud Gateway:

  • 在父工程的 pom.xml 中:
xml 复制代码
<dependencyManagement>
    <dependencies>
        <!-- 统一管理版本 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-gateway-dependencies</artifactId>
            <version>3.1.5</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
  • 在子模块中:
xml 复制代码
<dependencies>
    <!-- 真正引入网关功能 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
</dependencies>

这样,子模块不需要写版本号,版本由父工程统一管理。


总结一句话

依赖 作用 使用场景
spring-cloud-starter-gateway 引入网关功能,包含所有运行时依赖 业务项目中直接引入
spring-cloud-gateway-dependencies 统一管理网关相关依赖版本(BOM) 父项目 dependencyManagement 中引入

结论

  • 开发网关 → 用 spring-cloud-starter-gateway
  • 管理版本 → 用 spring-cloud-gateway-dependencies(BOM)

这两个依赖不是替代关系 ,而是互补关系

相关推荐
xxjj998a1 天前
PHP vs Java:核心区别与应用场景全解析
java·开发语言·php
用户298698530141 天前
Java 从零生成 Word 文档:段落、图片与表格操作
java·后端
2401_833269301 天前
Java IO流:从字节到字符的桥梁
java·开发语言
月落归舟1 天前
深入剖析乐观锁背后的原理
java·乐观锁
SimonKing1 天前
OpenCode 在 IDEA 中使用 ACP 协议 VS 直接使用 TUI,哪个编程方式更是你的菜?
java·后端·程序员
NE_STOP1 天前
Redis--持久化之AOF
java
budingxiaomoli1 天前
注册中心的其他实现-Nacos
java·spring cloud·微服务
大大大大晴天️1 天前
Flink技术实践-Flink重启策略选型指南
java·大数据·flink
ffqws_1 天前
Spring @Transactional 注解详解:从入门到避坑
java·数据库·后端·spring
xuhaoyu_cpp_java1 天前
单调栈(算法)
java·数据结构·经验分享·笔记·学习·算法