解决使用多模块开发中依赖版本不一致问题

项目概况:父工程myblog下有三个模块,admin,blog和framework。其中framework是公共模块,admin,blog两个模块都引入了公共模块。

问题发现:由于服务器配置较低,无法安装mysql8.0版本,所以只能选择使用5.7。所以就在framework中指定数据库驱动版本号(默认为8.0.15)

<!--mysql数据库驱动-->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.48</version>
</dependency>

但是启动项目后,发现报错。经过排查错误,发现admin,blog两个子模块中的依赖版本依然是8.0.15。

查阅资料发现是maven依赖原则导致。

maven依赖的三大优先原则

1.依赖最短路径优先原则 一个项目Demo依赖了两个jar包,其中A-B-C-X(1.0) , A-D-X(2.0)。由于X(2.0)路径最短,所以项目使用的是X(2.0)。

2.pom文件中申明顺序优先 如果A-B-X(1.0) ,A-C-X(2.0) 这样的路径长度一样怎么办呢?这样的情况下,maven会根据pom文件声明的顺序加载,如果先声明了B,后声明了C,那就最后的依赖就会是X(1.0)。

3.覆盖优先原则 子pom内声明的优先于父pom中的依赖

问题原因:由于其他三个模块都是直接依赖于父工程的,引入了framework模块之后路径变长。父工程是一个springboot工程,默认mysql版本为8.0.15,由于没有显式设置mysql驱动版本,所以使用了默认版本。根据最短路径原则,admin和blog模块会选择直接依赖父工程中的版本。

解决方案:在父工程中约束子模块中依赖版本号

<dependencyManagement>
    <dependencies>
        <dependency>
             <groupId>mysql</groupId>
             <artifactId>mysql-connector-java</artifactId>
             <version>5.1.48</version>
        </dependency>
    </dependencies>
</dependencyManagement>

dependencyManagement可以统一管理项目中依赖包的版本号,不会实际引入jar。当需要变更版本号时只需在父pom中修改即可;如果某个子项目需要指定一个特殊的版本号时,只需要在自己项目的pom.xml中显示声明一个版本号即可,此时子项目会使用自己声明的版本号,而不继承父项目的版本号。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当多模块项目遇到依赖父工程class找不到的问题时,可以采取以下方法解决。 1. 检查父工程的pom.xml文件:确认父工程的pom.xml文件是否正确设置了相应的依赖项和版本号。检查父工程是否包含了所需的class,并确认版本一致。 2. 检查子模块的pom.xml文件:确认子模块的pom.xml文件是否正确引用了父工程,并且依赖所需的class。 3. 执行“clean install”命令:在父工程目录下运行命令“mvn clean install”清理并编译整个项目,并将生成的jar或war文件安装到本地仓库。这将确保所有的依赖项被正确安装到本地。 4. 检查项目的目录结构:确保父工程和子模块的目录结构正确,并且模块之间的依赖关系正确设置。 5. 检查IDE的配置:如果使用的是开发工具如IntelliJ IDEA或Eclipse,可以检查IDE的配置,确保正确的classpath和构建路径设置。 6. 检查依赖的作用域:在子模块的pom.xml文件,确保所需的class的依赖项的作用域设置正确。如果需要在编译时使用依赖,可以设置为“compile”作用域;如果仅在运行时使用,可以设置为“runtime”作用域。 7. 更新依赖项的版本:如果以上方法都无效,可以尝试更新相关依赖项的版本号,以解决可能的依赖冲突或兼容性问题。 通过以上方法,可以解决模块项目依赖父工程class找不到的问题,确保项目顺利编译和运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值