Eclipse下的Maven增量编译

时间:2016-01-28 08:09:54

标签: eclipse maven m2eclipse

我最近将一个大型(丑陋)遗留项目转换为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中的设置可以帮助什么?还有其他想法吗?

由于

2 个答案:

答案 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个线程)加速。