如何解决Sonarqube java.lang.OutOfMemoryError:Java堆空间

问题描述 投票:0回答:3

我正在使用 Sonarqube 社区版本。我收到以下错误,

Exception in thread "LOG_FLUSHER" Exception in thread "CHECKPOINT_WRITER" java.lang.OutOfMemoryError: Java heap space
        at java.util.ArrayList.iterator(ArrayList.java:840)
        at java.util.Collections$SynchronizedCollection.iterator(Collections.java:2031)
        at com.persistit.Persistit.pollAlertMonitors(Persistit.java:2285)
        at com.persistit.Persistit$LogFlusher.run(Persistit.java:192)
java.lang.OutOfMemoryError: Java heap space
        at java.util.HashMap$Values.iterator(HashMap.java:968)
        at com.persistit.Persistit.earliestDirtyTimestamp(Persistit.java:1439)
        at com.persistit.CheckpointManager.pollFlushCheckpoint(CheckpointManager.java:271)
        at com.persistit.CheckpointManager.runTask(CheckpointManager.java:301)
        at com.persistit.IOTaskRunnable.run(IOTaskRunnable.java:144)
        at java.lang.Thread.run(Thread.java:748)
WARNING: WARN: [JOURNAL_FLUSHER] WARNING Journal flush operation took 7,078ms last 8 cycles average is 884ms
INFO: ------------------------------------------------------------------------
INFO: EXECUTION FAILURE
INFO: ------------------------------------------------------------------------
INFO: Total time: 1:17.852s
ERROR: Error during SonarQube Scanner execution
ERROR: Java heap space
ERROR:

Exception: java.lang.OutOfMemoryError thrown from the UncaughtExceptionHandler in thread "CLEANUP_MANAGER"
INFO: Final Memory: 40M/989M
INFO: ------------------------------------------------------------------------
The SonarQube Scanner did not complete successfully

我已经更改了 sonar.properties 中的大小,但我仍然面临同样的问题。怎么解决这个问题。

sonar.web.javaOpts=-Xmx4G -Xms2048m -XX:+HeapDumpOnOutOfMemoryError
sonar.ce.javaOpts =-Xmx4G -Xms2048m -XX:+HeapDumpOnOutOfMemoryError 
sonar.search.javaOpts=-Xmx4G -Xms2048m -XX:+HeapDumpOnOutOfMemoryError
sonarqube sonarqube-scan sonarqube-ops sonarqube-web
3个回答
11
投票

您更改的是为 SonarQube 本身分配内存的服务器端设置。

您需要更改的是为分析进程分配内存的构建代理端设置。您还没有说您正在使用哪种分析仪,因此细节会略有不同,但是

  • 适用于 SonarQube 扫描仪
    export SONAR_SCANNER_OPTS="-Xmx512m"
  • 适用于 Maven 的 SonarQube 扫描仪
    export MAVEN_OPTS="-Xmx512m"

2
投票

尝试使用以下分析属性缩小要扫描/分析的文件范围。将源直接从 Workspace 指向 SRC 路径,可以避免其他不需要的文件,并且可以消耗很少的内存。或添加大尺寸文件的排除。

sonar.language=java
sonar.sources=Proj1/sub1/src
sonar.java.binaries=.
sonar.exclusions=**/*.docx,**/*.zip,**/*.ear

另外,请单独尝试使用以下 Java 内存或堆内存选项。

sonar.web.javaOpts=-Xmx1024m -Xms512m
sonar.web.javaOpts=-Xmx1024m -Xms512m -XX:+HeapDumpOnOutOfMemoryError
sonar.ce.javaOpts=-Xmx2048m -Xms512m
sonar.ce.javaOpts=-Xmx12g -Xms3g -XX:+HeapDumpOnOutOfMemoryError

另外,尝试更新下面的环境变量

ANT_OPTS=-Xms512m -Xmx1800m
SONAR_SCANNER_OPTS=-Xmx1024m -Xms512m
SONAR_RUNNER_OPTS=-Xmx1024m -XX:MaxPermSize=512m

以上所有属性也可以添加到“$SONARQUBE_HOME/conf/sonar.properties”文件中。


1
投票

项目中的大文件会导致此问题,对我来说,50MB 的 XML 文件会出现此错误,并且该文件对分析过程并不重要。我在配置文件(SonarQube.Analysis.xml)中排除了这个文件,问题就解决了

© www.soinside.com 2019 - 2024. All rights reserved.