Java VM的元空间已满运行

问题描述

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

此外,这是我的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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...