Дженкинс выдает ошибку «Исключение в потоке «main» java.lang.OutOfMemoryError: превышен лимит накладных расходов GC «?

#jenkins #sonarqube #sonarqube-scan

#дженкинс #sonarqube #sonarqube-сканирование

Вопрос:

При создании проекта в jenkins я получаю ошибку OutofBoundMemory. журнал выглядит следующим образом..

 Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded
    at org.sonar.sslr.internal.vm.Machine.createNode(Machine.java:256)
    at org.sonar.sslr.internal.vm.Instruction$RetInstruction.execute(Instruction.java:305)
    at org.sonar.sslr.internal.vm.Machine.execute(Machine.java:162)
    at org.sonar.sslr.internal.vm.Machine.execute(Machine.java:106)
    at org.sonar.sslr.internal.vm.Machine.parse(Machine.java:84)
    at org.sonar.sslr.parser.ParseRunner.parse(ParseRunner.java:45)
    at com.sonar.sslr.api.typed.ActionParser.parse(ActionParser.java:102)
    at com.sonar.sslr.api.typed.ActionParser.parse(ActionParser.java:91)
    at org.sonar.php.PHPAnalyzer.nextFile(PHPAnalyzer.java:71)
    at org.sonar.plugins.php.PHPSensor.analyseFile(PHPSensor.java:142)
    at org.sonar.plugins.php.PHPSensor.analyseFiles(PHPSensor.java:124)
    at org.sonar.plugins.php.PHPSensor.analyse(PHPSensor.java:115)
    at org.sonar.batch.phases.SensorsExecutor.executeSensor(SensorsExecutor.java:58)
    at org.sonar.batch.phases.SensorsExecutor.execute(SensorsExecutor.java:50)
    at org.sonar.batch.phases.AbstractPhaseExecutor.execute(AbstractPhaseExecutor.java:83)
    at org.sonar.batch.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:192)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127)
    at org.sonar.batch.scan.ProjectScanContainer.scan(ProjectScanContainer.java:241)
    at org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:236)
    at org.sonar.batch.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:226)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127)
    at org.sonar.batch.task.ScanTask.execute(ScanTask.java:47)
    at org.sonar.batch.task.TaskContainer.doAfterStart(TaskContainer.java:86)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127)
    at org.sonar.batch.bootstrap.GlobalContainer.executeTask(GlobalContainer.java:106)
    at org.sonar.batch.bootstrapper.Batch.executeTask(Batch.java:119)
    at org.sonarsource.scanner.api.internal.batch.BatchIsolatedLauncher.execute(BatchIsolatedLauncher.java:62)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  

Даже сборка продолжается, я думаю, долгое время.. Я использую sonarqube runner
Что мне делать?

Ответ №1:

Во вводе «Параметры JVM» на этапе сборки вам необходимо указать больше памяти (чем по умолчанию) для процесса. Вот как это может выглядеть:

-Xmx2g -Xms512m -XX:MaxPermSize= 512m

Обратите внимание, что вы должны настроить эти значения в зависимости от ваших системных ресурсов.

Комментарии:

1. ПРЕДУПРЕЖДЕНИЕ: [JOURNAL_FLUSHER] ПРЕДУПРЕЖДЕНИЕ Операция очистки журнала заняла 13 180 мс, за последние 8 циклов среднее значение составляет 1647 мс. Я получаю это предупреждение. Я установил значения равными 1024. Не могли бы вы рассказать, что это значит