Sonar分析给出内存不足错误,我应该增加Ant或Sonar服务器的JVM堆空间



我正在分析Sonar中的一个大型项目,并得到以下错误:

[sonar:sonar] 03:55:39.511 INFO  p.PhasesTimeProfiler - Execute decorators...
BUILD FAILED
[...]
[...] java.lang.OutOfMemoryError: Java heap space
at org.sonar.batch.index.MeasurePersister.model(MeasurePersister.java:127)
at org.sonar.batch.index.MeasurePersister.getMeasuresToSave(MeasurePersister.java:117)
at org.sonar.batch.index.MeasurePersister.dump(MeasurePersister.java:70)
at org.sonar.batch.index.DefaultPersistenceManager.dump(DefaultPersistenceManager.java:63)
at org.sonar.batch.phases.Phases.execute(Phases.java:95)
at org.sonar.batch.bootstrap.ProjectModule.doStart(ProjectModule.java:139)
at org.sonar.batch.bootstrap.Module.start(Module.java:83)
at org.sonar.batch.bootstrap.BatchModule.analyze(BatchModule.java:131)
at org.sonar.batch.bootstrap.BatchModule.doStart(BatchModule.java:121)
at org.sonar.batch.bootstrap.Module.start(Module.java:83)
at org.sonar.batch.bootstrap.BootstrapModule.doStart(BootstrapModule.java:121)
at org.sonar.batch.bootstrap.Module.start(Module.java:83)
at org.sonar.batch.Batch.execute(Batch.java:104)
at org.sonar.ant.Launcher.execute(Launcher.java:78)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:616)
at org.sonar.ant.SonarTask.delegateExecution(SonarTask.java:244)
at org.sonar.ant.SonarTask.execute(SonarTask.java:193)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:616)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:392)
at org.apache.tools.ant.Target.performTasks(Target.java:413)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
at org.apache.tools.ant.helper.SingleCheckExecutor.executeTargets(SingleCheckExecutor.java:38)
at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
at org.apache.tools.ant.taskdefs.Ant.execute(Ant.java:442)

应该增加正在运行的Sonar服务器的java堆空间,还是应该增加正在执行Sonar作业的Ant目标的java堆空间?

从堆栈跟踪中可以看到,Ant启动了Sonar分析,因此您应该为Ant运行的VM增加堆空间。

这是一个非常相似的问题:如何增加Sonar Java堆空间

命令行Ant用法

引自Mark O'Connor对另一个问题的回答:

Sonar ANT任务作为ANT的一部分执行,因此您需要使用标准ANT环境参数设置JVM堆。例如:

出口ANT_OPTS = -Xmx256m

备注:

  • 这是用于Linux的,对于Windows,使用set命令
  • 这严格适用于堆空间。对于Permgen,使用-XX:MaxPermSize=<desired amount>

这是一个更类似的问题:Build Failed Java .lang. outofmemoryerror: Java heap space

引自文章http://soenkerohde.com/2008/06/change-eclipse-ant-settings-when-you-run-out-of-memory/

    在Eclipse中打开菜单:运行->外部工具->打开外部工具对话框
  • 在左侧选择要更改的构建脚本
  • 选择右边的JRE选项卡
  • 设置如下VM参数: -Xms768m -Xmx1024m -XX:MaxPermSize=512m

For IntelliJ Idea

这个论坛的线程是有用的:ANT构建java堆空间

引自答案:

请确保您在正确的位置增加堆。你需要点击IDEA的Ant工具窗口中的"属性"按钮,并在那里编辑的"最大堆大小(Mb)"字段。

另外,来自IntelliJ Idea页面:增加内存堆

引自文章:

构建进程的内存堆独立于IntelliJ IDEA内存堆,在构建进程完成后释放。

增加内存堆:打开构建文件属性对话框。在最大堆大小字段中,键入所需的内存量。

For Jenkins Continuous Integration and Ant build

这个问题是有用的:如何使用Java Options在jenkins ant构建工具设置ANT_OPTS

引自答案:

设置JAVA选项为-Xmx512m -XX:MaxPermSize=256m,不带ANT_OPTS=

对于Maven构建,这篇文章很有用:如何在hudson构建中增加Maven堆空间

  1. 导航到您的hudson作业,
  2. 点击 ,
  3. 向下滚动到Build部分,和
  4. 点击高级按钮。
  5. 将此输入MAVEN_OPTS: -Xmx512m -XX:MaxPermSize=128m

相关内容

  • 没有找到相关文章

最新更新