maven项目由于多个依赖中含有同一个jar包导致的冲突问题的解决办法

今天在利用mapreduce对HBase进行输入输出的时候,发生了一件很无厘头的事情,我和同事写同样的代码,但是我成功了,而他却失败了,这就有点让人头疼。一开始我们以为是配置的问题,但是经过比对,配置并没有什么不同。因此,我就将mapreduce的执行过程看了一遍,结果发现,他的org.apache.hadoop.conf.Configuration 类和我的org.apache.hadoop.conf.Configuration类是不同的,发现这个问题之后,就好办了许多。这就是jar包的版本问题所导致的,那么我们两的依赖导入版本没有什么不同,为什么会发生jar包不同的事情呢?

这就涉及到maven项目加载依赖的机制,根据“artifactId”标签中的内容开始加载,如果依赖中已经存在了相同的jar包,那么即使版本不同也不会再次加载,所以pom.xml中依赖的添加顺序也是十分重要的。我跟同事的依赖都一样,但是我导入的hadoop依赖在前,hbase的依赖在后,因此我的hadoop-common版本是按照hadoop的版本加载的2.6.4的版本,而他的hadoop-common的版本却是根据hbase的版本所加载的2.5.1的版本,这就导致我们相同的代码产生了不同的结果。


我们只是一个小小的测试,如果是对于大的项目,那么这就必须引起注意,要不然总是会发生一些无厘头的异常,影响项目的进度。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值