问题描述
我试图让我的Java代码运行,但是每当尝试尝试时,元空间就会开始变满。起初我什至没有注意到它,因为它要花很长时间(〜1个月)才能完全运行并崩溃。
我要做的第一件事是查看代码,如果有对象正在创建并填充了很多数据,并且未被GC删除。确定不是(很可能)不是这种情况后,我编写了一个小的测试程序,导致了相同的错误。
在我的主程序中,我调用一个新的TimerTask并为其分配一个计时器。然后,我只安排它。
TestTimer testTimerTask = new TestTimer();
Timer timer = new Timer("test");
timer.scheduleAtFixedrate(testTimerTask,100);
在这里,TimerTask本身仅创建了一堆对象,之后应将其删除。
public class TestTimer extends TimerTask{
private long x = 0;
@Override
public void run() {
String str = "";
for (int i = 0; i < 10000; i++) {
if(x >= 2147483647) {
x = 0;
}
str = new String("" + x);
x++;
}
}
}
所以我尝试了调试。为此,我使用了VisualVM的2.0.4版本。 在运行了一段时间后,我得到了Metaspace和Heap的这两张图片。
此外,这是我的JVM参数,
-xms64m
-Xmx128m
-Dlog4j.configurationFile=./log4j2.xml
我的JVM版本 OpenJDK 64位服务器VM(11.0.8 + 10,混合模式)和我的Java版本版本11.0.8,卖方Oracle Corporation 。 / p>
有什么办法可以解决此问题并阻止我的元空间填满?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)