Sonar - OutOfMemoryError: Java heap space

59,952

Solution 1

I had the same problem and found a very different solution, perhaps because I'm having a hard time swallowing the previous answers / comments. With 10 million lines of code (that's more code than is in an F16 fighter jet), if you have a 100 characters per line (a crazy size), you could load the whole code base into 1GB of memory. I set it 8GB of memory and it still failed. Why?

Answer: Because the community Sonar C++ scanner seems to have a bug where it picks up ANY file with the letter 'c' in its extension. That includes .doc, .docx, .ipch, etc. Hence, the reason it's running out of memory is because it's trying to read some file that it thinks is 300mb of pure code but really it should be ignored.

Solution: Find the extensions used by all of the files in your project (see more here):

dir /s /b | perl -ne 'print $1 if m/\.([^^.\\\\]+)$/' | sort -u | grep c

Then add these other extensions as exclusions in your sonar.properties file:

sonar.exclusions=**/*.doc,**/*.docx,**/*.ipch

Then set your memory limits back to regular amounts.

%JAVA_EXEC% -Xmx1024m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=128m %SONAR_RUNNER_OPTS% ...

Solution 2

this has worked for me:

SONAR_RUNNER_OPTS="-Xmx3062m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=128m"

I set it direct in the sonar-runner(.bat) file

Solution 3

I had the same problem when running sonar with maven. In my case it helped to call sonar separately:

mvn clean install && mvn sonar:sonar

instead of

mvn clean install sonar:sonar

http://docs.sonarqube.org/display/SONAR/Analyzing+with+Maven

Remark: Because my solution is connected to maven, this is not the direct answer for the question. But it might help other users who stumple upon it.

Solution 4

I know this thread is a bit old but this info might help someone.

For me the problem was not like suggested by the top-answer with the C++ plugin. Instead my problem was the Xml-Plugin (https://docs.sonarqube.org/display/PLUG/SonarXML) after I deactivated it the analysis worked again.

Solution 5

What you can do it to create your own quality profile with just some Findbugs rules at first, and then progressively add more and more until you reach his OutOfMemoryError. There's probably only a single rule that makes all this fail because your code violates it - and if you deactivate this rule, it will certainly work.

Share:
59,952

Related videos on Youtube

shekhar verma
Author by

shekhar verma

Senior Software Engineer(Quality), Ixigo.com Gurgaon

Updated on October 21, 2020

Comments

  • shekhar verma
    shekhar verma over 3 years

    I am deploying a large Java project on Sonar using "Findbugs" as profile and getting the error below:

    Caused by: java.util.concurrent.ExecutionException: java.lang.OutOfMemoryError:
    Java heap space
    

    What i have tried to resolve this:

    1. Replaced %SONAR_RUNNER_OPTS% with -Xms256m -Xmx1024m to increase the heap size in sonar-runner bat file.
    2. Put "sonar.findbugs.effort" parameter as "Min" in Sonar global parameters.

    But both of above methods didn't work for me.

  • Denim Datta
    Denim Datta over 10 years
    for me, its giving Invalid maximum heap size: -Xmx512m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=128m Could not create the Java virtual machine.
  • adnan kamili
    adnan kamili almost 8 years
    remove "=" from the passed values
  • zacran
    zacran over 7 years
    export SONAR_SCANNER_OPTS="-Xmx3062m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=128m" if you're using SonarQube Scanner 2.5+ and are on Linux
  • kinjelom
    kinjelom about 7 years
    if you use maven and still have this problem: export MAVEN_OPTS="-Xms256m -Xmx1024m"
  • posix99
    posix99 almost 7 years
    export SONAR_SCANNER_OPTS="-Xmx3062m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=128m" Worked on windows too, in regards to @zacran comment.
  • K J
    K J about 3 years
    Option doesn't exist in current (assuming latest codebase) SonarCloud...?