news 2026/6/10 9:57:47

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/6/10 15:36:56

10 个课堂汇报降重工具,本科生AI查重率优化推荐

10 个课堂汇报降重工具&#xff0c;本科生AI查重率优化推荐 论文写完才发现&#xff0c;降重才是真正的挑战 对于大多数本科生来说&#xff0c;课堂汇报、课程论文、文献综述等任务几乎是学习生活中的“必修课”。然而&#xff0c;当这些任务完成之后&#xff0c;真正让人头疼的…

作者头像 李华
网站建设 2026/6/10 15:37:10

C#实战:如何开发设计毫秒级延迟、工业级稳定的Windows平台RTSP/RTMP播放器

在视频监控、远程操控、无人机图传及智慧城市等专业领域&#xff0c;一个“能播”的播放器远远不够。行业对播放器的要求早已上升到毫秒级延迟、极致的稳定性、丰富的功能集以及优雅的代码实现。 虽然市面上存在 FFmpeg、VLC 等开源方案&#xff0c;但在 Windows C# (WinForms…

作者头像 李华
网站建设 2026/6/10 14:24:33

8个降AI率工具推荐,本科生论文必备!

8个降AI率工具推荐&#xff0c;本科生论文必备&#xff01; 论文被AI检测“盯上”&#xff0c;你真的无计可施了吗&#xff1f; 对于大多数本科生来说&#xff0c;毕业论文不仅是学习成果的总结&#xff0c;更是通向未来的重要一步。然而&#xff0c;随着人工智能技术的广泛应用…

作者头像 李华
网站建设 2026/6/10 12:21:58

测试文章标题02

测试文章内容这是一篇测试文章

作者头像 李华
网站建设 2026/6/10 11:57:16

3步搞定Editly Docker部署:告别复杂配置的视频编辑新体验

3步搞定Editly Docker部署&#xff1a;告别复杂配置的视频编辑新体验 【免费下载链接】editly Slick, declarative command line video editing & API 项目地址: https://gitcode.com/gh_mirrors/ed/editly 还在为视频编辑工具的繁琐安装而头疼吗&#xff1f;Editly…

作者头像 李华
网站建设 2026/6/10 12:19:00

清华镜像站同步更新|Qwen-Image模型国内高速下载通道开放

清华镜像站同步更新&#xff5c;Qwen-Image模型国内高速下载通道开放 在AIGC浪潮席卷全球的今天&#xff0c;图像生成技术早已不再是实验室里的概念玩具。从电商海报到影视分镜&#xff0c;从品牌设计到教育插图&#xff0c;文生图模型正以前所未有的速度渗透进各行各业。然而…

作者头像 李华