news 2026/3/8 13:11:43

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/3/4 8:05:41

10个降AI率工具推荐,专科生开题必备!

10个降AI率工具推荐&#xff0c;专科生开题必备&#xff01; 当AI痕迹成了论文的“致命伤” 对于许多专科生来说&#xff0c;开题报告和论文写作是大学生活中最让人头疼的一环。尤其是现在&#xff0c;随着AI技术的广泛应用&#xff0c;很多同学在撰写论文时都会借助一些AI工…

作者头像 李华
网站建设 2026/3/7 0:28:49

9 个降AI率工具,本科生开题演讲稿推荐

9 个降AI率工具&#xff0c;本科生开题演讲稿推荐 论文写作的困境&#xff1a;时间、重复率与降重的三重压力 对于大多数本科生而言&#xff0c;开题报告和演讲稿的撰写无疑是大学阶段最令人头疼的任务之一。从选题到文献综述&#xff0c;再到最终的成文&#xff0c;每一个环节…

作者头像 李华
网站建设 2026/3/2 13:43:25

8 个自考文献综述工具,AI降ai率推荐与对比

8 个自考文献综述工具&#xff0c;AI降ai率推荐与对比 文献综述的重担&#xff0c;你真的扛得住吗&#xff1f; 对于自考学生来说&#xff0c;论文写作从来不是一件轻松的事。尤其是文献综述部分&#xff0c;它不仅是对已有研究成果的梳理和总结&#xff0c;更是展现学术素养的…

作者头像 李华
网站建设 2026/3/3 20:27:56

数据驱动决策:如何利用BI工具挖掘大数据商业价值?

数据驱动决策&#xff1a;如何用BI工具像“寻宝”一样挖掘大数据商业价值&#xff1f; 关键词&#xff1a;数据驱动决策、BI工具、商业价值挖掘、数据可视化、指标体系、决策流程、实战案例 摘要&#xff1a;你有没有过这样的经历&#xff1f;家里的便利店想多赚点钱&#xff0…

作者头像 李华
网站建设 2026/3/4 17:13:43

SQL 总结

SQL 总结 引言 SQL(Structured Query Language)是一种用于管理关系数据库的标准化查询语言。自从1970年代诞生以来,SQL 已经成为数据库管理领域的事实标准。本文将对SQL的核心概念、常用命令以及实际应用进行总结,帮助读者全面了解和学习SQL。 SQL 基础知识 关系数据库…

作者头像 李华
网站建设 2026/3/5 15:32:14

JSP 表达式语言

JSP 表达式语言 概述 JSP(JavaServer Pages)是一种基于Java技术的服务器端页面技术,它允许开发者使用Java代码编写动态网页。在JSP页面中,表达式语言(Expression Language,简称EL)是一种用于简化表达式编写和减少代码量的技术。本文将详细介绍JSP表达式语言的概念、语…

作者头像 李华