java.lang.OutOfMemoryError:与Jenkins和Maven的PermGen

时间:2013-12-31 05:05:29

标签: maven junit jenkins

我的Jenkins工作中出现以下异常: -

java.lang.OutOfMemoryError: PermGen space
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:791)
at java.lang.ClassLoader.defineClass(ClassLoader.java:634)
at org.powermock.core.classloader.MockClassLoader.loadUnmockedClass(MockClassLoader.java:201)
at org.powermock.core.classloader.MockClassLoader.loadModifiedClass(MockClassLoader.java:149)
at org.powermock.core.classloader.DeferSupportingClassLoader.loadClass(DeferSupportingClassLoader.java:67)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at org.apache.log4j.LogManager.<clinit>(LogManager.java:86)
at org.slf4j.impl.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:64)
at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:270)
at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:281)

...

我通过Maven在这个工作中运行我的Junit测试用例。正如Jenkins所建议的,我有一个新的全局属性MAVEN_OPTS,其值高达-XX:MaxPermSize=1024m 但我仍然继续得到java.lang.OutOfMemoryError: PermGen

非常感谢任何帮助。

2 个答案:

答案 0 :(得分:11)

感谢Stefan的回答。不幸的是,添加默认的log4j类加载器并没有解决我的问题。但是,您提供的链接解决了这个问题。

我必须在我的“maven-surefire-plugin”定义中添加以下配置: -

<argLine>-XX:PermSize=512m -XX:MaxPermSize=1024m</argLine>

这解决了我的问题。

答案 1 :(得分:3)

PowerMock有类加载内容引起的内存泄漏:https://code.google.com/p/powermock/issues/detail?id=346

您可以使用log4j类的默认类加载器:

@RunWith(PowerMockRunner.class)
@PowerMockIgnore(value = {"org.apache.log4j.*"})
public class YourTest {
    ...
}