axis2 jar包冲突_用好这几个技巧,解决Maven Jar包冲突易如反掌

本文深入剖析了Maven的依赖传递原则与Jar包冲突的原理,通过案例展示了如何使用Maven Helper插件定位冲突,并提供了排除法、版本锁定法等解决冲突的实用技巧,旨在帮助开发者打造干净的POM文件,降低维护成本。
摘要由CSDN通过智能技术生成

前言

大家在项目中肯定有碰到过Maven的Jar包冲突问题,经常出现的场景为:

本地运行报NoSuchMethodError,ClassNotFoundException。明明在依赖里有这个Jar包啊。怎么运行不了!?

项目中明明定义着某个jar包版本为2.0.2,怎么打包之后变成2.5.0了!?

A项目引xxx.jar包运行好好的,B项目同样引入xxx.jar后,运行报错了。。是B项目有问题,还是xxx.jar包有问题!?

本地环境和测试环境运行的好好的,到了生产就报一堆NoSuchMethodError,是我人品有问题还是生产环境有问题!?

这样的问题如果不熟悉maven依赖机制的同学排查起来,估计挺头痛的。

而且maven依赖结构不好的项目,在引入新的Jar包时的风险也是巨大的。小则影响性能,大则引起生产发布和运行时异常。

其实以上问题的根源都来自于Maven的Jar包冲突和使用不当的依赖传递。这篇文章我就好好分析下以下3个内容:

  • 依赖传递的原则和产生Jar包冲突的原理分析
  • 定位冲突以及解决Jar包冲突的几个简单技巧
  • 如何写一个干净依赖关系的POM文件

依赖传递原则

几乎所有的Jar包冲突都和依赖传递原则有关,所以我们先说Maven中的依赖传递原则:

最短路径优先原则

假如引入了2个Jar包A和B,都传递依赖了Z这个Jar包:

A -> X -> Y -> Z(2.5)
B -> X -> Z(2.0)

那其实最终生效的是Z(2.0)这个版本。因为他的路径更加短。如果我本地引用了Z(3.0)的包,那生效的就是3.0的版本。一样的道理。

最先声明优先原则

如果路径长短一样,优先选最先声明的那个。

A -> Z(3.0)
B -> Z(2.5)

这里A最先声明,所以传递过来的Z选择用3.0版本的。

Jar包冲突的原理

假设我们项目中依赖了A和B两个Jar包。而A和B各自又有以下传递依赖

A -> X -> Z(2.0)
B -> X -> Y -> Z(2.5)

那最终系统中Z包就产生了冲突,2.0和2.5两个版本冲突。但是classpath中只会依赖一个版本的Z包。根据传递依赖的最短路径优先原则,最终依赖的应该是2.0版本。

如果Y包中用了Z包2.5版本中新的method时候,当运行到这段逻辑的时候。就会报NoSuchMethodError了。因为本来依赖的是2.5版本,但是因为Jar包冲突Maven选择了2.0版本,2.0版本中又没有这个新的method,导致出错。

但要注意的是,不是所有冲突都会引起运行异常。相反,大部分公司的项目都会有一些Jar包冲突,但其实没有造成运行时的问题。

这是因为很多传递依赖的Jar包,不管是2.0版本也好,2.5版本也好,都可以运行。

只有高版本Jar包不向下兼容,或者新增了某些低版本没有的API才有可能导致这样的问题

定位冲突

IDEA提供了一个maven依赖分析神器:Maven Helper

a0e4083eb7313804d0c4af5d00efd774.png

用这个插件能很好的显示出项目中所有的依赖树和冲突

89adfe8f63b423933a46017047b6205c.png

这里面红色高亮的部分,就表明这个Jar包有了冲突。选中这个jar包,可以看到这2个版本的冲突的来源。

上图的例子,表明cruator-client这个Jar包,有2个传递依赖,分别为2.5.0版本和4.0.1版本。冲突的描述为:

omitted for conflict with 2.5.0. 由于与2.5.0版本冲突而被省略

具体的层级在右边也一目了然了,所以maven最终根据最短路径优先原则选择了2.5.0版本,4.0.1版本被忽略。

这时候有同学会问:本地环境我可以利用Maven Helper来定位,那么预生产或者生产环境呢。又没有IDEA,如何定位冲突的细节?

可以利用mvn命令来解决:

mvn dependency:tree -Dverbose
此处一定不要省略-Dverbose参数,要不然是不会显示被忽略的包的

de2ab1d2e8899932ca53849ac8b882d4.png

其实mvn命令行一样好用。非常清晰明确。

解决Jar包冲突的几个实用技巧

排除法

还是上面的那个例子,现在生效的是2.5.0,如果想生效4.0.1。只需要在2.5.0上面点exclude就行了。

7160465ded947539416db09e4ac3aec5.png

版本锁定法

如果很多个依赖都传递了Jar包A,涉及了很多个版本,但是你只想指定一个版本。用排除法一个个去exclude太麻烦,而且exclude在pom文件中也会体现,太多的话,也影响代码整洁和阅读感受。

这时候需要用到版本锁定法

何谓版本锁定法?公司的项目一般都会有父级pom,你想指定哪个版本只需要在你项目的父POM中(当然在本工程内也可以)定义如下:(还是举上个例子,指定4.0.1版本)

<dependencyManagement>
    <dependency>
        <groupId>org.apache.curator</groupId>
        <artifactId>curator-client</artifactId>
        <version>4.0.1</version>
    </dependency>
</dependencyManagement>

锁定版本法可以打破2个依赖传递的原则,优先级为最高

锁定版本后,依赖树为:

7525f03c14d7e78ab51ee28d7a3d0788.png

都统一变成4.0.1,锁定版本有一个好处:版本锁定并不排除Jar包,而且显示的把所有版本不一致的Jar包变成统一一个版本,这样在阅读代码时比较友好。也不用忍受一大堆的exclude标签。

如何写一个干净依赖关系的POM文件

我本人是有些轻度代码洁癖的人,所以即便是pom文件的依赖关系也想干净而整洁。如何写好干净的POM呢,作者认为有几点技巧要注意:

  • 尽量在父POM中定义<dependencyManagement>,来进行本项目一些依赖版本的管理,这样可以从很大程度上解决一定的冲突
  • 如果是提供给别人依赖的Jar包,尽可能不要传递依赖不必要的Jar包
  • 使用mvn dependency:analyze-only命令用于检测那些声明了但是没被使用的依赖,如有有一些是你自己声明的,那尽量去掉
  • 使用mvn dependency:analyze-duplicate命令用来分析重复定义的依赖,清理那些重复定义的依赖

最后

其实庞大的项目依赖传递也一定多。但是不管多复杂的依赖关系,看到不要害怕。就这么几条原则,细心的去分析,所有的依赖都有迹可循。

这些传递依赖如果管理的好,能让你的维护成本大大降低。如果管不好,这群野孩子每一个都可能是引发下一个NoSuchMethodError的导火索。

原文链接:https://www.toutiao.com/i6855830914120090116/

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Axis2是一个基于Java的Web服务框架,它提供了一种构建和部署Web服务的方法。要使用Axis2,需要用到一些jar包。其中axis2-kernel.jar、axis2-adb.jar、axis2-transport-http.jar等等。axis2-kernel.jar是Axis2的核心jar包含了所有必要的类和资源,如服务引擎和消息处理程序等。axis2-adb.jar是Axis2的异步消息处理框架,它能够在处理大量消息时保证系统的高效性。axis2-transport-http.jar是用于处理HTTP传输的jar包,它含了HTTP传输所必须的类和资源。axis2还有许多其他的jar包,如axis2-saaj.jar、axis2-xmlbeans.jar等等,它们都提供了特定的功能和基础库支持。总之,在使用Axis2构建和部署Web服务时,需要根据具体的需求选择相应的jar包,并正确配置系统环境,确保系统能够正常运行。 ### 回答2: axis2是一个Apache Software Foundation开发的Web服务框架。为使用axis2,需要引入相应的jar包。具体如下: 1. axis2-kernel.jar axis2框架基本的核心API和服务引擎。需要使用它来构建你的axis2服务。 2. axis2-adb.jar 提供对数据绑定框架的支持。这个模块为WSO2 Data Services和二进制传输提供了主要的支持。 3. axis2-transport-http.jar 提供对HTTP传输协议的支持。如果你需要使用HTTP协议向axis2服务发送请求或响应,你需要使用它。 4. axis2-codegen.jar 提供轻松快捷的机制为WSDL文档生成代码。它支持多种代码生成技术。 5. axis2-xmlbeans.jar 在使用XMLBeans技术进行数据绑定时提供支持。 6. axis2-jaxws.jar 提供支持JAX-WS协议的机制。 7. axis2-jaxrs.jar 提供支持RESTful风格的WEB服务协议的机制。 简而言之,axis2是一个强大的Web服务框架,其jar包提供了一系列的依赖库,使得开发者具有更多的控制力和灵活性。 ### 回答3: Axis2是一个基于Java的Web服务框架,可以用于构建和部署Web服务。它主要有三个核心组件:Axis2内核、Axis2客户端和Axis2工具Axis2内核是Axis2的核心组件,提供了处理Web服务请求和响应的API。Axis2客户端是提供给客户端使用的工具,用于构造和发送Web服务请求。Axis2工具是提供给开发者使用的一组辅助工具,括生成代码、管理模块和配置Web服务等。 在使用Axis2时需要引入一些关键的Jar包,如axis2-kernel、axis2-transport-http、axis2-transport-local、axis2-xmlbeans等。其中,axis2-kernel含了Axis2的核心代码,是使用Axis2框架必不可少的jar包axis2-transport-http是用于通过HTTP协议进行Web服务通信的jar包axis2-transport-local用于在同一JVM进程中的不同组件之间实现Web服务通信。axis2-xmlbeans则是处理XML消息的jar包,如果要使用XML格式的消息进行通信,则需要引入该jar包。 除了以上的核心jar包外,还有一些其他的jar包可以用于扩展Axis2的功能,如axis2-jaaxws、axis2-mtompolicy等。axis2-jaaxws提供了Java API for XML Web Services (JAX-WS)的支持,可以用于构建基于JAX-WS的Web服务。axis2-mtompolicy提供了对Message Transmission Optimization Mechanism (MTOM)的支持,可以用于在Web服务中传输二进制数据。 总之,Axis2是一个非常强大的Web服务框架,有很多依赖的jar包,使用时需要根据具体需求选择引入相关的jar包,以支持所需功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值