1

我一直在将我们的 maven 构建服务器从 Maven 2 迁移到 Maven 3。我正在设置 maven 以使用 scp 将新的 java 应用程序部署到远程服务器。但是,当我运行“mvn install”时,会收到以下消息。

    [INFO] ------------------------------------------------------------------------
    [INFO] Reactor Build Order:
    [INFO]
    [INFO] FooCorp Parent Project
    [INFO] FooCorp Daemons
    [INFO] FooCorp Transport Objects and Interfaces
    [INFO] FooCorp Web Client
    [INFO] FooCorp Web Application
    [INFO]
    [INFO] ------------------------------------------------------------------------
    [INFO] Building FooCorp Parent Project S88-SNAPSHOT
    [INFO] ------------------------------------------------------------------------
    [INFO]
    [INFO] --- maven-install-plugin:2.3:install (default-install) @ Foo ---
    [INFO] Installing /home/ubuntu/FooCorp/pom.xml to /home/ubuntu/mvn_local_repo/com/Foo/Foo/S88-SNAPSHOT/Foo-S88-SNAPSHOT.pom
    [INFO]
    [INFO] --- maven-deploy-plugin:2.8.2:deploy (default-deploy) @ Foo ---
    Downloading: scp://mvn.FooCorp.com/var/www/maven2/com/Foo/Foo/S88-
SNAPSHOT/maven-metadata.xml
Exception in thread "pool-1-thread-1" java.lang.OutOfMemoryError: Java heap space
    at com.jcraft.jsch.IdentityFile.decrypt_rsa(IdentityFile.java:648)
    at com.jcraft.jsch.IdentityFile.decrypt(IdentityFile.java:553)
    at com.jcraft.jsch.IdentityFile.setPassphrase(IdentityFile.java:435)
    at com.jcraft.jsch.JSch.addIdentity(JSch.java:225)
    at com.jcraft.jsch.JSch.addIdentity(JSch.java:207)
    at com.jcraft.jsch.JSch.addIdentity(JSch.java:200)
    at org.apache.maven.wagon.providers.ssh.jsch.AbstractJschWagon.openConnectionInternal(AbstractJschWagon.java:133)
    at org.apache.maven.wagon.AbstractWagon.openConnection(AbstractWagon.java:115)
    at org.apache.maven.wagon.AbstractWagon.connect(AbstractWagon.java:217)
    at org.sonatype.aether.connector.wagon.WagonRepositoryConnector.connectWagon(WagonRepositoryConnector.java:345)
    at org.sonatype.aether.connector.wagon.WagonRepositoryConnector.pollWagon(WagonRepositoryConnector.java:385)
    at org.sonatype.aether.connector.wagon.WagonRepositoryConnector$GetTask.run(WagonRepositoryConnector.java:571)
    at org.sonatype.aether.util.concurrency.RunnableErrorForwarder$1.run(RunnableErrorForwarder.java:60)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)

这是有关我正在使用的系统的一些信息。

:> echo $MAVEN_OPTS
-Xmx2000m -Xms256m
:> mvn --version
Apache Maven 3.0.5
Maven home: /usr/share/maven
Java version: 1.7.0_65, vendor: Oracle Corporation
Java home: /usr/lib/jvm/java-7-openjdk-amd64/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.13.0-36-generic", arch: "amd64", family: "unix"

在 4GB 总内存的 Ubuntu 14.04 上运行。

每次运行时我都会收到相同的错误消息mvn install。在java堆空间异常之前的最后一个命令中下载的文件 Downloading: scp://mvn.FooCorp.com/var/www/maven2/com/Foo/Foo/S88-SNAPSHOT/maven-metadata.xml ......远程服务器上确实存在(我可以访问它,所以我检查了)。根据 MA​​VEN_OPTS,Maven 似乎有足够的内存。另外,我使用 top 命令观察了系统内存,它几乎没有使用超过 1.5GB 的内存。我已经看过许多其他解决方案来解决诸如此类的问题,它们都涉及给 Maven 更多内存,但我认为 2GB 应该可以满足 maven 的任何需求(我可能错了)。不确定这是否有帮助,但我能够运行“mvn install”并且它运行良好。唯一的问题是 Maven 部署命令。

wagon 插件在我的 POM.xml 中配置,如下所示

<extensions>
    <extension>
        <groupId>org.apache.maven.wagon</groupId>
        <artifactId>wagon-ssh</artifactId>
        <version>2.4</version>
    </extension>
</extensions>

并且 maven-deploy-plugin 配置在 POM 中配置如下......

<plugin>
    <artifactId>maven-deploy-plugin</artifactId>
    <version>2.8.2</version>
    <configuration>
        <argLine>-Xmx3000m</argLine>
     </configuration>
</plugin>

我一直很难解决这个问题,不知道还有什么可以尝试的。任何可能的解决方案或一般建议将不胜感激。

如有必要,我可以添加更多信息。

感谢您提供任何帮助。

4

1 回答 1

1

尝试增加堆大小。PFB链接供参考。希望这可以帮助你。

http://javarevisited.blogspot.com/2011/08/increase-heap-size-maven-ant.html

http://javarevisited.blogspot.com/2011/09/javalangoutofmemoryerror-permgen-space.html

:> 回声 $MAVEN_OPTS -Xmx2000m -Xms256m

尝试将突出显示的粗体的大小增加到 -Xms512m 并再次尝试

于 2014-12-16T03:38:15.283 回答