news 2026/5/1 9:34:20

Maven依赖冲突怎么解决?Jar包冲突排查指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Maven依赖冲突怎么解决?Jar包冲突排查指南

Maven依赖冲突怎么解决?Jar包冲突排查指南

项目跑着好好的,突然就报错了:

NoSuchMethodError ClassNotFoundException

别慌,十有八九是Maven依赖冲突。今天教你怎么排查和解决。

为什么会冲突?

假设你的项目同时依赖了A和B两个库:

项目依赖 A 项目依赖 B A 依赖 Guava 30.0 B 依赖 Guava 31.0

Maven只会选一个版本的Guava,但A和B各自需要的版本不同,就可能出问题。

常见报错

NoSuchMethodError:

java.lang.NoSuchMethodError: com.google.common.xxx

原因:运行时加载的类版本和编译时不一致,某个方法在低版本里没有。

ClassNotFoundException:

java.lang.ClassNotFoundException: org.apache.xxx

原因:依赖被排除了或者根本没引入。

排查方法

第一步:查看依赖树

mvn dependency:tree

会显示项目所有依赖的层级关系。

第二步:搜索特定依赖

依赖树太长看不过来,可以过滤:

# 只看guava相关mvn dependency:tree -Dincludes=com.google.guava

第三步:看冲突详情

mvn dependency:tree -Dverbose

会显示被省略的依赖:

+- com.example:lib-a:jar:1.0 | \- com.google.guava:guava:jar:30.0 (被选中) \- com.example:lib-b:jar:2.0 \- (com.google.guava:guava:jar:31.0 - 被省略,和30.0冲突)

这样就能看出谁引入了哪个版本。

解决方法

方法1:排除依赖

让A不要带着它的Guava:

<dependency><groupId>com.example</groupId><artifactId>lib-a</artifactId><version>1.0</version><exclusions><exclusion><groupId>com.google.guava</groupId><artifactId>guava</artifactId></exclusion></exclusions></dependency>

方法2:强制指定版本

在项目中直接声明依赖,覆盖传递依赖:

<!-- 强制使用31.0版本 --><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>31.0-jre</version></dependency>

方法3:用dependencyManagement统一版本

<dependencyManagement><dependencies><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>31.0-jre</version></dependency></dependencies></dependencyManagement>

所有模块都会使用这个版本。

常见冲突案例

案例1:日志框架冲突

SLF4J: Class path contains multiple SLF4J bindings.

项目里同时有logback和log4j的实现,需要排除一个:

<dependency><groupId>xxx</groupId><artifactId>xxx</artifactId><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId></exclusion></exclusions></dependency>

案例2:Jackson版本不一致

Incompatible Jackson version

用BOM统一版本:

<dependencyManagement><dependencies><dependency><groupId>com.fasterxml.jackson</groupId><artifactId>jackson-bom</artifactId><version>2.15.0</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>

IDEA插件帮忙

装个Maven Helper插件,可视化看依赖冲突:

  1. 打开pom.xml
  2. 点底部的Dependency Analyzer
  3. 红色的就是冲突的依赖
  4. 右键可以直接排除

比命令行方便多了。

预防措施

1. 用BOM管理版本

SpringBoot项目继承parent就自动管理了很多依赖版本:

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.2.0</version></parent>

2. 定期检查

mvn dependency:analyze

会提示哪些依赖用了但没声明,哪些声明了但没用。

本地没问题服务器报错?

有时候本地好好的,部署到服务器就冲突。可能是服务器环境的jar包和本地不一样。

我用星空组网把本地和服务器连起来,直接SSH上去看:

# 看实际加载了哪个版本的jarcd/app/libls-la|grepguava

或者启动时看类加载:

java -verbose:class -jar app.jar|grepguava

能快速定位是哪个版本被加载了。

小结

依赖冲突排查流程:

  1. mvn dependency:tree -Dincludes=xxx找到冲突
  2. 确定需要的版本
  3. exclusion排除 或 直接声明覆盖
  4. 再次dependency:tree验证

记住:用BOM管理版本能避免大部分冲突。

有问题评论区交流~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 23:57:43

LeaguePrank终极教程:免费打造专属英雄联盟个性化形象

LeaguePrank终极教程&#xff1a;免费打造专属英雄联盟个性化形象 【免费下载链接】LeaguePrank 项目地址: https://gitcode.com/gh_mirrors/le/LeaguePrank 想要在英雄联盟中展现独一无二的个性风采&#xff1f;LeaguePrank正是你需要的完美解决方案&#xff01;这款基…

作者头像 李华
网站建设 2026/4/30 22:46:15

LobeChat界面美学设计揭秘:为何用户第一眼就爱上它?

LobeChat界面美学设计揭秘&#xff1a;为何用户第一眼就爱上它&#xff1f; 在AI聊天机器人几乎随处可见的今天&#xff0c;打开一个新工具时&#xff0c;你是否曾因为某个界面“特别顺眼”而多停留了几分钟&#xff1f;又或者&#xff0c;仅仅几秒之内&#xff0c;你就决定关掉…

作者头像 李华
网站建设 2026/4/30 22:46:10

UC3842反激式开关电源上电前测试方法

在UC3842反激式开关电源上电前进行测试&#xff0c;主要是为了避免可能的故障和损坏。以下是一些原因&#xff1a;● 避免炸毁UC3842芯片&#xff1a;在上电之前进行测试可以确认UC3842芯片的参数是否符合规范&#xff0c;包括启动电压。若UC3842有故障&#xff0c;可能会在上电…

作者头像 李华
网站建设 2026/4/30 22:46:14

25 岁转行晚了?网安工程师手把手带你入门到精通,来得及!

25岁&#xff0c;转行网络安全工程师来还来得及吗&#xff1f;手把手带你入门到精通&#xff0c;一切都来得及&#xff01; 25岁&#xff0c;转行网络安全工程师来还来得及吗&#xff1f; 首先说一下这个行业的现状&#xff0c;真正科班出身网络安全专业的很少&#xff0c;因…

作者头像 李华
网站建设 2026/4/30 22:46:16

AXI-A7.4.5 Request attribute restrictions for Atomic transactions

上述是AXI协议中对原子事务请求属性(AWCACHE、AWDOMAIN、AWSNOOP、AWLOCK)的限制规则,主要目的是确保原子操作的正确执行和系统一致性。 1. AWCACHE和AWDOMAIN可以任意组合 规则:原子事务可以使用接口允许的任何AWCACHE(缓存属性)和AWDOMAIN(域属性)组合。 举例: 一…

作者头像 李华