我一直在将我们的 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
......远程服务器上确实存在(我可以访问它,所以我检查了)。根据 MAVEN_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>
我一直很难解决这个问题,不知道还有什么可以尝试的。任何可能的解决方案或一般建议将不胜感激。
如有必要,我可以添加更多信息。
感谢您提供任何帮助。