Maven Deploy插件

时间:2014-12-16 03:02:59

标签: java maven maven-3 heap-memory maven-deploy-plugin

我一直在将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"

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

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

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>

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

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

感谢您提供任何帮助。

1 个答案:

答案 0 :(得分:1)

尝试增加堆大小。 PFB链接供参考。希望这对您有帮助。

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

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

产品:&gt; echo $ MAVEN_OPTS -Xmx2000m -Xms256m

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