我试图让我的 Java 代码运行,但每当我尝试元空间开始变满。起初我什至没有注意到它,因为它需要很长时间(约 1 个月)才能完全运行并崩溃。
我做的第一件事是查看代码,是否有正在创建的对象并填充了大量数据并且没有被 GC 删除。在确定这(很可能)不是这种情况后,我编写了一个导致相同错误的小测试程序。
在我的 main 中,我调用了一个新的 TimerTask 并为其分配了一个 Timer。之后我只是安排它。
TestTimer testTimerTask = new TestTimer();
Timer timer = new Timer("test");
timer.scheduleAtFixedRate(testTimerTask, 0, 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。
我能做些什么来解决这个问题并阻止我的元空间填满吗?