Clojure 如何查找和管理依赖冲突。

Clojure How To Find and Manage Dependency conflicts.

我最近 运行 遇到一个问题,在我的项目中包含一个新的依赖关系破坏了另一个不相关的功能。

有问题的两个:

[amazonica "0.3.132"]
[abengoa/clj-stripe "1.0.4"]

包括上面的条带会破坏亚马逊的条带,并为 s3 操作抛出以下错误

ERROR org/apache/http/conn/SchemePortResolver
java.lang.NoClassDefFoundError: org/apache/http/conn/SchemePortResolver
    at com.amazonaws.http.apache.client.impl.ApacheHttpClientFactory.<init>(ApacheHttpClientFactory.java:41)

删除条带库修复了 Amazon 的条带库,所以我开始怀疑那里存在某种冲突。我的问题是,如何找出导致问题的原因并加以解决。

我在 repo 上发现了类似的问题:https://github.com/mcohen01/amazonica/issues/294

已用

修复
[clj-facebook-graph "0.4.0" :exclusions [clj-http]]

但我想知道如何找出导致问题的 Stripe 库中的内容,以及如何在不破坏库的情况下进入并修复它。我也对如何执行此操作的更一般的想法感兴趣,所以如果我再次遇到它,我可以解决这个问题。

如果您使用的是 Leiningen,则可以使用 lein deps :tree 来打印有用的调试信息,并且在打印依赖关系树之前,它会打印建议的排除项以避免这些类型的问题:

$ lein deps :tree
...
[com.taoensso/faraday "1.9.0"] -> [com.taoensso/encore "2.67.2"] -> [com.taoensso/truss "1.3.3"]
overrides
[amazonica "0.3.112" :exclusions [com.amazonaws/amazon-kinesis-client com.amazonaws/aws-java-sdk com.amazonaws/dynamodb-streams-kinesis-adapter]] -> [com.taoensso/nippy "2.12.2"] -> [com.taoensso/encore "2.68.0"] -> [com.taoensso/truss "1.3.4"]

Consider using these exclusions:
[amazonica "0.3.112" :exclusions [com.amazonaws/amazon-kinesis-client com.taoensso/truss com.amazonaws/dynamodb-streams-kinesis-adapter com.amazonaws/aws-java-sdk]]
...

根据我的经验,排除精确的传递冲突仍然需要反复试验。我在 AWS SDK、Jackson 等方面遇到过类似问题

对于这样的问题,没有真正的灵丹妙药。在 leiningen 项目中发现问题的最佳开始是 运行 deps 任务。例如:

lein deps :tree

例如在一个随机项目中产生以下结果:

Possibly confusing dependencies found:
[org.clojure/clojurescript "1.9.293"] -> [org.clojure/tools.reader "1.0.0-beta3"]
 overrides
[cljfmt "0.6.0" :exclusions [org.clojure/clojure]] -> [rewrite-cljs "0.4.4"] -> [org.clojure/tools.reader "1.0.5"]
 and
[cljfmt "0.6.0" :exclusions [org.clojure/clojure]] -> [org.clojure/tools.reader "1.2.2"]

Consider using these exclusions:
[cljfmt "0.6.0" :exclusions [org.clojure/clojure org.clojure/tools.reader]]

这些是开始的提示。在该初始块之后,您将看到整个可传递依赖树。例如:

[cljfmt "0.6.0" :exclusions [[org.clojure/clojure]]]
  [com.googlecode.java-diff-utils/diffutils "1.3.0"]
  [org.clojure/tools.cli "0.3.7"]
  [rewrite-clj "0.6.0"]
  [rewrite-cljs "0.4.4"]

您可以尝试从那里进行更多调查。