当Maven项目很大,或者你运行诸如 mvn site 这样的命令的时候,maven运行需要很大的内存,在默认配置下,就可能遇到java的堆溢出。如:
[INFO] ------------------------------------------------------------------------
[ERROR] FATAL ERROR
[INFO] ------------------------------------------------------------------------
[INFO] Java heap space
[INFO] ------------------------------------------------------------------------
[INFO] Trace
java.lang.OutOfMemoryError: Java heap space
at java.lang.AbstractStringBuilder.expandCapacity(AbstractStringBuilder.java:99)
at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:518)
...
at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 7 minutes 14 seconds
[INFO] Finished at: Wed Sep 05 07:44:55 CEST 2007
[INFO] Final Memory: 37M/63M
[INFO] ------------------------------------------------------------------------
解决的方法是调整java的堆大小的值。
Windows环境中
找到文件%M2_HOME%\bin\mvn.bat ,这就是启动Maven的脚本文件,在该文件中你能看到有一行注释为:
@REM set MAVEN_OPTS=-Xdebug -Xnoagent -Djava.compiler=NONE...
它的意思是你可以设置一些Maven参数,我们就在注释下面加入一行:
之后,当你运行Maven命令如 mvn -version 的时候,你会看到如下的输出:
E:\test>set MAVEN_OPTS= -Xms128m -Xmx512m
Maven version: 2.0.9
Java version: 1.6.0_07
OS name: "windows 2003" version: "5.2" arch: "x86" Family: "windows"
我们看到,配置的Maven选项生效了,OutOfMemoryError也能得以相应的解决。
Linux环境中
也可以通过设置环境变量解决该问题, 如,编辑文件 /etc/profile 如下
export JAVA_HOME MAVEN_HOME MAVEN_OPTS JAVA_BIN PATH CLASSPATH
如果你使用Hudson
用 Hudson + Maven做持续集成,并不幸也遇到了类似的错误,那么上述两种方式都将不再起作用了,因为Hudson使用自己的maven-agent来启动Maven,不会去调用Maven的脚本,自然相应的配置也就无效了。
好在Hudson也给为我们提供了配置点,在Hudson的项目配置页面中,有一块Build区域,这里我们已经设置了Root Pom和Goals。注意该区域的右下角有一个"Advanced..."按钮,点击会看到MAVEN_OPTS输入框,这里输入"-Xmx512m"就OK了。
m2eclipse中
类似以上的方法都会失效,所幸m2eclipse提供了配置点。步骤如下:
项目上右击 -> Run As -> Run Configurations -> Maven Build 上右击 -> New
这时会看到一个maven运行配置对话框,这里面其它的配置我不多解释了,为了解决内存溢出的问题,我们可以选择第二个TAB: JRE,然后在VM arguments中输入配置如:-Xms128m -Xmx512m。
相关推荐
5. **内存不足问题**:如果你收到“Out of Memory”错误,可能是因为Tomcat服务器的内存设置过低。可以修改Tomcat的bin/catalina.bat(Windows)或bin/catalina.sh(Linux/Mac)文件,增加-Xms和-Xmx参数来增大堆...
Java中的`java.lang.OutOfMemoryError`是一种常见的运行时错误,通常表示应用程序在尝试分配新的内存对象时,Java虚拟机(JVM)无法找到足够的连续内存空间来完成操作。这个错误可能由多种原因引起,主要分为堆内存...
1. **内存溢出**:如果遇到“Out of Memory”错误,可以在IDE的`Help > Edit Custom VM Options`中增加堆内存分配。 2. **启动慢**:可以优化启动速度,如关闭不必要的启动服务、禁用不必要的插件。 3. **代码提示...
Java连接达梦数据库驱动dm_jdbc: ...dm_jdbc\Dm7Dictionary.jar dm_jdbc\Dm7JdbcDriver14.jar dm_jdbc\Dm7JdbcDriver15.jar dm_jdbc\Dm7JdbcDriver16.jar dm_jdbc\Dm7JdbcDriver17.jar dm_jdbc\dmgeo_1.6.jar ...
- **Spark Driver OOM(Out of Memory):** 当Driver进程的内存不足时,可以通过增加`spark.driver.memory`的值来缓解。 - **Executor OOM:** Executor进程的内存溢出可以通过调整`spark.executor.memory`来优化...
在Android开发中,图片处理是个复杂的问题,因为图片大小不一,可能会导致内存溢出(Out of Memory,OOM)等问题。Glide通过智能地管理内存和磁盘缓存,解决了这些问题。它能够根据屏幕尺寸和设备性能自动调整图片...
它采用了一种叫做"流式图像管道"的设计,可以有效地管理内存,防止因大图导致的OOM(Out of Memory)错误,并且支持WebP格式,以及动态GIF和WebP动图的播放。 ### 2. 为何选择Fresco? - **内存优化**:Fresco将...
此外,如果工程较大,在构建过程中可能会因为Java内存不足导致“java out of memory”错误。针对这个问题,可以在用户目录下的.gradle文件夹中创建一个gradle.properties文件,并填入相应的配置参数,比如指定JVM的...