如何(安全地)在Eclipse中删除不必要的Maven依赖项



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

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

mvn dependency:analyze

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

是否有一种普遍接受的最佳实践方法来处理这个问题?还是我听天由命,一个接一个地删除这些(可能)未使用的依赖项,确保在删除每个依赖项后不会有任何损坏?

您可以尝试在打开java -verbose:class选项的情况下运行代码。这将生成输出,显示每个类从哪里(哪个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文件进行排序/分组。

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

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

最新更新