9

我正在 Eclipse 中开发一个 Java 项目,使用 Maven 构建和管理依赖项。该项目分布在 5 个 Eclipse 项目中,其中一个是父 POM。我正在开发一个服务器实现,它基于另一个团队实现的更复杂的服务器。因此,我的工作基于他们预先存在的代码和 POM 文件,现在跨这些 Eclipse 项目的 POM 中有许多不必要的依赖项。

相对来说,我是一个Maven初学者,但是对这个命令比较熟悉:

mvn dependency:analyze

当我使用 Eclipse Maven 插件运行这个命令时,我会得到一长串“未使用的声明的依赖项”,但是当我尝试删除其中的一些时,我的程序会中断,有时会以神秘的方式中断。

是否有一种普遍接受的最佳实践方法来处理这个问题?或者我是否愿意一一删除这些(可能)未使用的依赖项,确保在删除每个依赖项后没有任何损坏?

4

2 回答 2

1

-verbose:class您可以尝试在打开 java 选项的情况下运行您的代码。这将生成输出,显示每个类的加载位置(哪个 jar 文件)。(注意:在 Sun JRE 上,这被写入标准输出;我认为在 IBM JRE 上,它被写入标准错误。)这是一个输出示例:

[Loaded junit.framework.AssertionFailedError from file:/D:/Documents%20and%20Settings/mike/.m2/repository/junit/junit/3.8.2/junit-3.8.2.jar]
[Loaded junit.framework.ComparisonFailure from file:/D:/Documents%20and%20Settings/mike/.m2/repository/junit/junit/3.8.2/junit-3.8.2.jar]
[Loaded org.jmock.core.SelfDescribing from file:/D:/Documents%20and%20Settings/mike/.m2/repository/jmock/jmock/1.2.0/jmock-1.2.0.jar]
[Loaded org.apache.log4j.spi.Configurator from file:/D:/Documents%20and%20Settings/mike/.m2/repository/log4j/log4j/1.2.9/log4j-1.2.9.jar]
[Loaded org.apache.log4j.xml.DOMConfigurator from file:/D:/Documents%20and%20Settings/mike/.m2/repository/log4j/log4j/1.2.9/log4j-1.2.9.jar]

只要您运行程序的大部分逻辑(以便加载所需的类),您就可以放心地假设verbose:class 输出中未提及的任何jar 都可以作为maven 依赖项删除。

您还可以对 verbose:class 输出进​​行搜索和替换,例如将其转换为 csv,然后将其放入电子表格程序中以按 jar 文件进行排序/分组。

仍然是相当多的手动工作,但至少它会给你一个开始的地方!

于 2013-07-08T20:03:05.913 回答
0

我不知道是否有普遍接受的最佳实践,因为从内省到服务的任何事情都可能在运行时中断。单元测试可以帮助你,但如果你没有很好的覆盖范围,它们可能会给你一种错误的安全感。删除每个软件包后,您仍然需要检查功能测试(希望是自动化的)。

于 2013-07-08T17:49:41.260 回答