我最近将一个大型(丑陋)遗留项目转换为Maven。这是一个非常庞大的项目(~2.7万行代码,以及java,jsp,js甚至VBS脚本的完美组合)并且结构不合理。所有东西都位于一个Maven工件下(因此是一个Eclipse项目)。
即使有这么糟糕的结构,它过去也可以从Eclipse中管理得更少或更少(即使有点慢),但现在,由于它是Mavenized,对源代码所做的每一次更改都会触发几乎完全重建的代码基础(以及2.7M LoC需要花费10分钟才能完成),这在每天都是无法使用的。
我发现以下与maven-compiler-plugin相关的错误报告,无法进行增量编译:https://issues.apache.org/jira/browse/MCOMPILER-205,我非常有信心这是我们性能问题的根源。
你有解决方法吗?你知道maven-compiler-plugin版本没有受到这个问题的影响吗?或者Eclipse中的设置可以帮助什么?还有其他想法吗?
由于
答案 0 :(得分:1)
Eclipse中的增量编译器(ecj,由JDT使用)完全覆盖了命令行Maven构建使用的编译器。任何maven-compiler-plugin或javac问题都应该被视为无关紧要。我希望m2e / Maven对单个项目工作空间没有重大影响,尽可能大。显然,既然你看到了相反的行为,那么显然某些东西正在减慢Maven构建器的速度。
由于你使用jsp和js文件,我猜这是一个战争项目。如果您正在使用Eclipse Java EE发行版,那么可以尝试的一件事是禁用m2e-wtp集成,看看它是否有所不同。转到首选项> Maven> Java EE集成并取消选中“启用Java EE配置”。
如果这没有帮助(或不适用于您的设置),您可以尝试的另一件事是在增量构建期间禁用Maven资源处理。在pom.xml中,尝试添加:
<profiles>
<profile>
<id>m2e</id>
<!-- This profile is only activated when building in Eclipse with m2e -->
<activation>
<property>
<name>m2e.version</name>
</property>
</activation>
<build>
<pluginManagement>
<plugins>
<!--This plugin's configuration is used to store Eclipse m2e settings
only. It has no influence on the Maven build itself. -->
<plugin>
<groupId>org.eclipse.m2e</groupId>
<artifactId>lifecycle-mapping</artifactId>
<version>1.0.0</version>
<configuration>
<lifecycleMappingMetadata>
<pluginExecutions>
<pluginExecution>
<pluginExecutionFilter>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-resources-plugin
</artifactId>
<versionRange>
[1.0,)
</versionRange>
<goals>
<goal>resources</goal>
<goal>testResources</goal>
</goals>
</pluginExecutionFilter>
<action>
<ignore></ignore>
</action>
</pluginExecution>
</pluginExecutions>
</lifecycleMappingMetadata>
</configuration>
</plugin>
</plugins>
</pluginManagement>
</build>
</profile>
</profiles>
它有可能破坏其他东西,但至少应该有助于确定资源处理是否是这里的罪魁祸首。
其他任何内容都需要更深入的分析,我建议您打开https://bugs.eclipse.org/bugs/enter_bug.cgi?product=M2E
的门票答案 1 :(得分:0)
Disable automatic build是您唯一的选择。只要你对这些文物感兴趣就可以构建。
你没说goals you are calling maven with。如果你不使用-DskipTests
运行所有测试(或者甚至不使用-Dmaven.test.skip=true
编译它们),或者如果不愿意跳过那些引入配置文件来运行必要的测试,那么它可能已经足够了。
由于您告诉它遗留项目我怀疑将项目结构更改为多模块maven项目超出了范围。然后,您可以尝试使用parallel builds(使用-T 4
(4个线程)或-T 2C
(每个核心2个线程)加速。