1

我试图让我的 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 版本。让它运行一段时间后,我得到了MetaspaceHeap的这两张图片。

此外,这是我的 JVM 参数,

-Xms64m
-Xmx128m
-Dlog4j.configurationFile=./log4j2.xml

我的 JVM 版本OpenJDK 64 位服务器 VM(11.0.8+10,混合模式)和我的 Java版本 11.0.8,供应商 Oracle Corporation

我能做些什么来解决这个问题并阻止我的元空间填满吗?

4

0 回答 0