java.lang.OutOfMemoryError: Java heap space in Maven
Solution 1
When I run maven test, java.lang.OutOfMemoryError happens. I google it for solutions and have tried to export MAVEN_OPTS=-Xmx1024m, but it did not work.
Setting the Xmx
options using MAVEN_OPTS
does work, it does configure the JVM used to start Maven. That being said, the maven-surefire-plugin forks a new JVM by default, and your MAVEN_OPTS
are thus not passed.
To configure the sizing of the JVM used by the maven-surefire-plugin, you would either have to:
- change the
forkMode
tonever
(which is be a not so good idea because Maven won't be isolated from the test) ~or~ - use the
argLine
parameter (the right way):
In the later case, something like this:
<configuration>
<argLine>-Xmx1024m</argLine>
</configuration>
But I have to say that I tend to agree with Stephen here, there is very likely something wrong with one of your test and I'm not sure that giving more memory is the right solution to "solve" (hide?) your problem.
References
Solution 2
For those new to Maven (like me) here is the whole config that goes in the build section of your pom. Cheers.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.19</version>
<configuration>
<argLine>-Xmx1024m</argLine>
</configuration>
</plugin>
</plugins>
</build>
Solution 3
To temporarily work around this problem, I found the following to be the quickest way:
export JAVA_TOOL_OPTIONS="-Xmx1024m -Xms1024m"
Solution 4
The chances are that the problem is in one of the unit tests that you've asked Maven to run.
As such, fiddling with the heap size is the wrong approach. Instead, you should be looking at the unit test that has caused the OOME, and trying to figure out if it is the fault of the unit test or the code that it is testing.
Start by looking at the stack trace. If there isn't one, run mvn ... test
again with the -e
option.
Solution 5
I have solved this problem on my side by 2 ways:
Adding this configuration in pom.xml
<configuration><argLine>-Xmx1024m</argLine></configuration>
Switch to used JDK 1.7 instead of 1.6
zjffdu
Committer of Pig/Tez/Livy/Zeppelin at The Apache Software Foundation
Updated on July 08, 2022Comments
-
zjffdu almost 2 years
When I run maven test,
java.lang.OutOfMemoryError
happens. I googled it for solutions and have tried toexport MAVEN_OPTS=-Xmx1024m
, but it did not work. Anyone know other solutions for this problem? I am using maven 3.0Paste the error message here when run
mvn test -e
Failed tests: warning(junit.framework.TestSuite$1) testDefaultPigJob_1(com.snda.dw.pig.impl.DefaultPigJobLocalTest) testDefaultPigJob_2(com.snda.dw.pig.impl.DefaultPigJobLocalTest) Tests run: 11, Failures: 3, Errors: 0, Skipped: 0 10/11/01 13:37:18 INFO executionengine.HExecutionEngine: Connecting to hadoop fi le system at: file:/// [INFO] ------------------------------------------------------------------------ [INFO] BUILD FAILURE [INFO] ------------------------------------------------------------------------ [INFO] Total time: 30.063s [INFO] Finished at: Mon Nov 01 13:37:18 PDT 2010 [INFO] Final Memory: 3M/6M [INFO] ------------------------------------------------------------------------ [ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2. 5:test (default-test) on project dw.pig: There are test failures. [ERROR] [ERROR] Please refer to E:\Code\Java\workspace\dw.pig\target\surefire-reports fo r the individual test results. [ERROR] -> [Help 1] org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal o rg.apache.maven.plugins:maven-surefire-plugin:2.5:test (default-test) on project dw.pig: There are test failures. Please refer to E:\Code\Java\workspace\dw.pig\target\surefire-reports for the in dividual test results. at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor .java:199) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor .java:148) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor .java:140) at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProje ct(LifecycleModuleBuilder.java:84) at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProje ct(LifecycleModuleBuilder.java:59) at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBu ild(LifecycleStarter.java:183) at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(Lifecycl eStarter.java:161) at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:314) at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:151) at org.apache.maven.cli.MavenCli.execute(MavenCli.java:445) at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:168) at org.apache.maven.cli.MavenCli.main(MavenCli.java:132) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl. java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces sorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Laun cher.java:290) at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.jav a:230) at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(La uncher.java:409) at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java: 352) Caused by: org.apache.maven.plugin.MojoFailureException: There are test failures . Please refer to E:\Code\Java\workspace\dw.pig\target\surefire-reports for the in dividual test results. at org.apache.maven.plugin.surefire.SurefirePlugin.execute(SurefirePlugi n.java:629) at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(Default BuildPluginManager.java:107) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor .java:195) ... 19 more [ERROR] [ERROR] Re-run Maven using the -X switch to enable full debug logging. [ERROR] [ERROR] For more information about the errors and possible solutions, please rea d the following articles: [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureExc
-
zjffdu over 13 years@Stephen,I can pass the test case in eclipse after I set-Xmx1024m in run configuration, but it always throw OutOfMemoryError when I run "mvn test" in console, even when I add -e options "mvn test -DMAVEN_OPTS=-Xmx1024m"
-
Stephen C over 13 years@zjffdu - You completely missed my point! The purpose of adding "-e" is not to make the tests work. It is to find out why they don't work.
-
zjffdu over 13 years@Stephen, I add the 'e' option, but did not get enough useful information.
-
Stephen C over 13 years@zjffdu - it says "Please refer to E:\Code\Java\workspace\dw.pig\target\surefire-reports for the individual test results". Did you??
-
Stephen C over 13 years@zjffdu - in that case, you'll need to debug this the hard way, like you would other Java problems.
-
Kevin Meredith almost 12 yearsDo you update the <configuration> tag only within your parent pom.xml?
-
djjeck over 11 yearsI get this problem while running GWT test cases, which simulate a full browser environment. Sometimes it's OK to increase the heap size.
-
Macarse about 11 years
forkMode
has been deprecated: maven.apache.org/surefire/maven-surefire-plugin/… -
Surekha over 9 yearsI was getting this error on mvn install, using "mvn install -DMAVEN_OPTS=-Xmx1024m" solved my problem!
-
rogerdpack about 9 years@Macarse
forkMode
has been deprecated, but I think only to be replaced withforkCount
which has similar functionality. One way you could use MAVEN_OPTS is<argLine>${env.MAVEN_OPTS}</argLine>
but that's apparently not recommended since it can vary from computer to computer (stackoverflow.com/a/10463133/32453). Also note that if you're using jacoco you're supposed to set argLine a different way stackoverflow.com/questions/12269558/maven-jacoco-plugin-error -
Kalle Richter about 7 yearsThen the error wouldn't be "Java heap space", but different.
-
swdev over 6 years+1 for mentioning MaxPermSize. If your out of memory error is caused by loading a bazillion classes like creating new HiveContext in your unit test, this is your solution.
-
Stephen C about 5 years@Surekha - Your problem is different to the one the OP was getting. He was getting this while running tests.
-
Stephen C about 5 years@djjeck - Yes sometimes. But I don't think it is the right solution most of the time.
-
Valerij Dobler over 3 yearsYour solution raises an
JUnitException: TestEngine with ID 'junit-jupiter' failed to discover test
when starting JUnit tests inside of IntelliJ. -
user674669 over 3 yearsOracle completely removed Perm gen space in the JDK 8 release. So, setting -XX:MaxPermSize will give a warning: "OpenJDK 64-Bit Server VM warning: Ignoring option MaxPermSize; support was removed in 8.0"