如何在 3rd 方库中查找依赖冲突

问题描述

我正在寻找一种在 3rd 方库中查找依赖项冲突的方法。我知道 mvn dependency:tree,它的 -Dverbose-Dincludes 选项。这很有效,但有几个缺点:

  • 我需要使用第 3 方依赖项设置 pom.xml 文件。这是一种有点迂回的方式,而且对于快速查看几个库的依赖项来说很乏味。
  • dependency:tree 下载所有依赖项,对于大型依赖项图,这可能会很慢并且消耗大量带宽。
  • dependency:tree -Dverbose 确实显示了冲突,但它非常冗长,因为它还显示了所有非冲突的依赖项。

解决方法

Coursier 依赖项解析器的 CLI 可以做到这一点。例如。要在 com.bynder:bynder-java-sdk:2.2.8 中查找依赖项冲突,您可以使用带有 resolve 标志的 Coursier 的 --conflict 命令:

$ cs resolve --conflicts   com.bynder:bynder-java-sdk:2.2.8 

org.jetbrains.kotlin:kotlin-stdlib-common:1.4.10 was selected,but
  com.squareup.okio:okio:2.8.0 wanted version 1.4.0

io.reactivex.rxjava2:rxjava:2.2.20 was selected,but
  com.squareup.retrofit2:adapter-rxjava2:2.9.0 wanted version 2.0.0

com.squareup.okhttp3:okhttp:4.9.0 was selected,but
  com.squareup.retrofit2:retrofit:2.9.0 wanted version 3.14.9

org.jetbrains.kotlin:kotlin-stdlib:1.4.10 was selected,but
  com.squareup.okio:okio:2.8.0 wanted version 1.4.0

这会输出一个冲突列表,仅此而已。除了元数据外,不会下载任何工件,整个过程非常快。

进一步探索冲突的地方,例如com.squareup.okhttp3:okhttp 来自,你可以运行

$ cs resolve com.bynder:bynder-java-sdk:2.2.8 --what-depends-on com.squareup.okhttp3:okhttp
  Result:
└─ com.squareup.okhttp3:okhttp:4.9.0
   ├─ com.squareup.okhttp3:logging-interceptor:4.9.0
   │  └─ com.bynder:bynder-java-sdk:2.2.8
   └─ com.squareup.retrofit2:retrofit:2.9.0 com.squareup.okhttp3:okhttp:3.14.9 -> 4.9.0
      ├─ com.bynder:bynder-java-sdk:2.2.8
      ├─ com.squareup.retrofit2:adapter-rxjava2:2.9.0
      │  └─ com.bynder:bynder-java-sdk:2.2.8
      └─ com.squareup.retrofit2:converter-gson:2.9.0
         └─ com.bynder:bynder-java-sdk:2.2.8

输出是一个反向依赖树,显示了依赖于 com.squareup.okhttp3:okhttp 的所有子树。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...