maven-assembly-plugin产生Java堆空间错误

3

在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步骤执行"mvn clean deploy"在开发Windows机器上可以正常工作。

已经尝试将MAVEN_OPTS设置为:

MAVEN_OPTS = -Xms256m -Xmx1024m
MAVEN_OPTS = -Xms512m -Xmx2048m

任何解决这个问题的线索吗?
1个回答

2
问题是关于在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>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接