2012-04-11 1 views
5

Я новичок в гидролокаторе. Я запускаю сонар из Дженкинса с гидролокатором пульгин.сонар findbugs куча размер

Когда я бегу от Jenkins я получаю из исключения памяти в FindBugs

ниже ошибка:

Out of memory 
Total memory: 1037M 
free memory: 30M 
Analyzed: D:\Victor\autocreated\webapp\WEB-INF\classes 
    Aux: C:\DOCUME~1\NADBHA~1\LOCALS~1\Temp\findbugs4165854405681394173.jar 
    Aux: C:\DOCUME~1\NADBHA~1\LOCALS~1\Temp\findbugs4688505485649811865.jar 
Total time: 2:04:49.155s 
Final Memory: 358M/989M 
Exception in thread "main" org.sonar.batch.bootstrapper.BootstrapException: org.sonar.api.utils.SonarException: Can not execute Findbugs 
    at org.sonar.runner.Runner.delegateExecution(Runner.java:189) 
    at org.sonar.runner.Runner.execute(Runner.java:78) 
    at org.sonar.runner.Main.main(Main.java:61) 
Caused by: org.sonar.api.utils.SonarException: Can not execute Findbugs 
    at org.sonar.plugins.findbugs.FindbugsExecutor.execute(FindbugsExecutor.java:120) 
    at org.sonar.plugins.findbugs.FindbugsSensor.analyse(FindbugsSensor.java:58) 
    at org.sonar.batch.phases.SensorsExecutor.execute(SensorsExecutor.java:64) 
    at org.sonar.batch.phases.Phases.execute(Phases.java:93) 
    at org.sonar.batch.bootstrap.ProjectModule.doStart(ProjectModule.java:143) 
    at org.sonar.batch.bootstrap.Module.start(Module.java:83) 
    at org.sonar.batch.bootstrap.BatchModule.analyze(BatchModule.java:111) 
    at org.sonar.batch.bootstrap.BatchModule.doStart(BatchModule.java:101) 
    at org.sonar.batch.bootstrap.Module.start(Module.java:83) 
    at org.sonar.batch.bootstrap.BootstrapModule.doStart(BootstrapModule.java:102) 
    at org.sonar.batch.bootstrap.Module.start(Module.java:83) 
    at org.sonar.batch.Batch.execute(Batch.java:100) 
    at org.sonar.runner.Launcher.executeBatch(Launcher.java:65) 
    at org.sonar.runner.Launcher.execute(Launcher.java:58) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at org.sonar.runner.Runner.delegateExecution(Runner.java:186) 
    ... 2 more 
Caused by: java.util.concurrent.ExecutionException: java.lang.OutOfMemoryError: Java heap space 
    at java.util.concurrent.FutureTask$Sync.innerGet(Unknown Source) 
    at java.util.concurrent.FutureTask.get(Unknown Source) 
    at org.sonar.plugins.findbugs.FindbugsExecutor.execute(FindbugsExecutor.java:112) 
    ... 20 more 
Caused by: java.lang.OutOfMemoryError: Java heap space 

мой сонар версия 2,13

когда я увеличивая JVM параметры в плагине соннера Jenkins до 1280 ниже:

Error occurred during initialization of VM 
Could not reserve enough space for object heap 
Error: Could not create the Java Virtual Machine. 
Error: A fatal exception has occurred. Program will exit`enter code here` 
+0

сколько памяти у вашей машины? 1280 кажется больше, чем доступный 1037M – oers

+0

мой системный барабан - 3 gb. – vinod

+0

Можете ли вы разместить параметры JVM, которые вы установили? –

ответ

5

Да, исполнитель сонарных findbugs может использовать много ОЗУ, если анализируемая база кода большая.

Вам необходимо увеличить не только размер кучи, доступный JVM, но также и «MaxPermSize» и «ReservedCodeCacheSize» (по крайней мере, для виртуальной машины Java Hotspot VM). Параметры JVM должны быть установлены на JVM, который фактически выполняет исполнитель сонара FindBugs. Так что, вероятно, не Дженкинс В.М., а тот, который Дженкинс начинает работать.

Вот пример для 64-битной системы:

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

На 32-битной системой, которую я предполагаю, вы используете, вы бы пойти на более низкие значения, такие как:

-Xmx1536m -XX:MaxPermSize=384m -XX:ReservedCodeCacheSize=128m 

Также , если Дженкинс не примет варианты JVM, вы можете попробовать запустить сонар, используя задачу сонара-муравья из Дженкинса. (Это то, что я делаю, и я могу установить столько памяти, сколько мне нравится.)

+0

пробовал все настройки thos через MAVEN_OPTS от Дженкинса, но, к сожалению, никакого успеха :( – gvasquez