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



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

有问题的两个:

[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)

删除条纹库可以修复亚马逊库,所以我开始怀疑那里存在某种冲突。我的问题是,我如何找出导致问题的原因,并解决它。

我在存储库中发现了类似的问题: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 开发工具包、杰克逊等方面遇到了类似的问题。

由于存在这样的问题,因此没有真正的灵丹妙药。 在莱宁根项目中发现问题的最佳开始是运行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]]

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

[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"]

你可以尝试从那里调查更多。

最新更新