在 TeamCity 构建中,有一个执行 maven-assembly-plugin 的步骤,在等待一段时间(40-50 分钟)后,它给出了 java 堆空间错误(参见日志):
[15:32:58][com.****:project] [INFO] --- maven-assembly-plugin:2.4:single (make-assembly) @ project ---
[15:33:01][com.****:project] [INFO] Reading assembly descriptor: assembly.xml
[16:20:02][com.****:project] [ERROR] Java heap space -> [Help 1]
Teamcity 正在 Unix 环境中执行。 Maven 步骤执行在开发 Windows 机器上正常工作的“mvn clean deploy”。
已经尝试将 MAVEN_OPTS 设置为:
MAVEN_OPTS = -Xms256m -Xmx1024m
MAVEN_OPTS = -Xms512m -Xmx2048m
有解决这个问题的线索吗?
最佳答案
问题出在 Unix 上的 maven-assembly-plugin 的配置上。
[09:21:17][com.***:project] [DEBUG] FileSet[lib/] dir perms: -1 file perms: -1 lineEndings: unix
[09:21:17][com.***:project] [DEBUG] The archive base directory is 'null'
存档基目录未在 pom.xml 配置中设置。出于这个原因,在 Unix 上,程序集正在归档 /lib 文件夹而不是 /projects/project/lib。因此,内存不足错误。
这是添加到当前配置的行:
<archiveBaseDirectory>${project.basedir}</archiveBaseDirectory>
这是生成的配置:
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<version>2.4</version>
<executions>
<execution>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
<configuration>
<finalName>project</finalName>
<appendAssemblyId>false</appendAssemblyId>
<archiveBaseDirectory>${project.basedir}</archiveBaseDirectory>
<descriptors>
<descriptor>assembly.xml</descriptor>
</descriptors>
</configuration>
</execution>
</executions>
</plugin>
关于java - maven-assembly-plugin 给出 java 堆空间错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18744351/