I have noticed a strange behavior of my scala compiler. It occasionally throws an OutOfMemoryError when compiling a class. Here's the error message:
[info] Compiling 1 Scala source to /Users/gruetter/Workspaces/scala/helloscala/target/scala-2.9.0/test-classes...
java.lang.OutOfMemoryError: PermGen space
Error during sbt execution: java.lang.OutOfMemoryError: PermGen space
It only happens once in a while and the error is usually not thrown on the subsequent compile run. I use Scala 2.9.0 and compile via SBT.
Does anybody have a clue as to what might be the cause for this error? Thanks in advance for your insights.
I am building with the Jenkins sbt plugin and had the same problems. They were resolved after copying the SBT_OPTS from the sbt file to the Jenkins job config's JVM flags.
I had this issue, played around with it for 10 minutes looking at sites trying to change the memory size.
Turns out i resolved it by,
Then,
This cleared it up for me.
Originally using a command like:
I got first OutOfMemoryError: PermGen space which I solved using
-XX:MaxPermSize
, and then OutOfMemoryError: Java heap space, to which-Xmx
was the remedy.So in my case, a command like this worked:
The cause for
OutOfMemoryError: PermGen space
is that it doesn't have enough permanent generation space :) If you are using Oracle JVM, you need to add the-XX:MaxPermSize=256M
(or some other amount of space) argument to yoursbt
script. For other JVMs, look at their documentation.I assumed you're using sbt 0.13.6 or higher. Create
.sbtopts
file in your sbt project's root with the following content:MaxMetaspaceSize
is for Java 8 whereasMaxPermSize
is for Java 7. They are critical to prevent out of memory errors related either to permgen or metaspace exhaustion. Of course, consider adapting flag values or adding any other flags required.More details and alternative approaches can be found in this blog post.
I use HomeBrew to install sbt on OS X. It supports a
SBT_OPTS
argument which can be put in~/.sbtconfig
file withexport SBT_OPTS=-XX:MaxPermSize=256M
.