我的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
。
非常感谢任何帮助。
答案 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 {
...
}