升级jar包可能遇到的两种依赖包冲突

No1:包版本冲突

类似这样:

Dependency convergence error for org.codehaus.jackson:jackson-jaxrs:1.9.13 paths to dependency are:
+-com.qunar.flight:business_statistic:1.0-SNAPSHOT
  +-org.apache.hive:hive-jdbc:1.2.1
    +-org.apache.hive:hive-shims:1.2.1
      +-org.apache.hive.shims:hive-shims-0.23:1.2.1
        +-org.apache.hadoop:hadoop-yarn-server-resourcemanager:2.6.0
          +-org.apache.hadoop:hadoop-yarn-common:2.7.1
            +-org.codehaus.jackson:jackson-jaxrs:1.9.13
and
+-com.qunar.flight:business_statistic:1.0-SNAPSHOT
  +-org.apache.hadoop:hadoop-common:2.5.1
    +-com.sun.jersey:jersey-json:1.9
      +-org.codehaus.jackson:jackson-jaxrs:1.8.3
]

这种情况是一种jar包被引入了不同的版本,产生冲突。比较好解决,只要用依赖管理<dependencyManagement>指定该jar包版本即可,一般用更新的版本


No2:类冲突

类似这样:

[ERROR] [Qunar Enforcer Rules] find DuplicateClasses
 
  Found in:
    org.slf4j:jcl-over-slf4j:jar:1.7.22:runtime
    commons-logging:commons-logging:jar:1.1.1:compile
  Duplicate classes:
    org/apache/commons/logging/impl/SimpleLog$1.class
    org/apache/commons/logging/Log.class
    org/apache/commons/logging/impl/SimpleLog.class
    org/apache/commons/logging/LogConfigurationException.class
    org/apache/commons/logging/impl/NoOpLog.class
    org/apache/commons/logging/LogFactory.class

这种情况是因为相同类被不同jar包引用,用依赖管理是无法解决问题的,只能排除掉其中一个。

<exclusions>
    <exclusion>
      <groupId>commons-logging</groupId>
      <artifactId>commons-logging</artifactId>
   </exclusion>
</exclusions>

这种冲突一般产生于log4j、slf4j、logback或者common包中,排除的时候要看自己的工程中用到的是哪一个包,将没有用到的那个排除掉

可使用mvn dependency:tree 或者IDEA的diagrams查看该类的包是由什么包引入的。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值