JDK 8 中的 PermGen 消除

IT小君   2021-09-16T02:33:37

我已经安装了 JDK 8 并尝试运行 Eclipse。我收到以下警告消息:

Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=512m;
support was removed in 8.0 

忽略此 VM 选项的原因是什么?

评论(6)
IT小君

忽略这些参数的原因是由于以下缺点,在 HotSpot for JDK8 中删除了永久生成

  • 启动时固定大小 - 难以调整。
  • 内部热点类型是 Java 对象:可以随完整 GC 移动,不透明,非强类型且难以调试,需要元元数据。
  • 简化完整集合:每个收集器的元数据的特殊迭代器
  • 想要同时释放类数据而不是在 GC 暂停期间
  • 启用受 PermGen 限制的未来改进。

永久代 (PermGen) 空间已被完全删除,取而代之的是一个名为 Metaspace 的新空间。删除 PermGen 的后果显然是PermSize 和 MaxPermSize JVM 参数被忽略,你永远不会得到 java.lang.OutOfMemoryError: PermGen 错误。

元空间的优势

  • 利用 Java 语言规范属性:类和关联的元数据生命周期与类加载器的相匹配
  • 每个装载机存储区域 – Metaspace
  • 仅线性分配
  • 没有单独的回收(除了 RedefineClasses 和类加载失败)
  • 没有 GC 扫描或压缩
  • 元空间对象没有重定位

元空间调整

可以使用 -XX:MaxMetaspaceSize 标志设置最大元空间大小,默认为无限制,这意味着只有您的系统内存是限制。-XX:MetaspaceSize 调整标志定义元空间的初始大小。如果不指定此标志,元空间将在运行时根据应用程序需求动态重新调整大小。

更改可以在未来实现其他优化和功能

  • 应用类数据共享
  • Young 集合优化,G1 类卸载
  • 元数据大小减少和内部 JVM 占用空间项目

GC 性能也有所提高。更多细节

2021-09-16T02:33:37   回复
IT小君

这是 Java 8 的新特性之一,是JDK Enhancement Proposals 122 的一部分

从 Hotspot JVM 中删除永久代,因此需要调整永久代的大小。

可以在JDK8 里程碑页面上找到将包含在 Java 8 中的所有JEP 的列表

2021-09-16T02:33:37   回复
IT小君

永久代 (PermGen) 空间已被完全删除,并被称为 Metaspace 的新空间所取代。 PermGen 删除的后果显然是 PermSize 和 MaxPermSize JVM 参数被忽略,您将永远不会收到java.lang.OutOfMemoryError: PermGen 错误。 JDK 8 HotSpot JVM 现在使用本机内存来表示类元数据,称为 Metaspace。 阅读更多>>

2021-09-16T02:33:38   回复
IT小君

因为永久代空间被移除了。内存管理发生了一些变化。

java-8-permgen-metaspace

2021-09-16T02:33:38   回复
IT小君

PermGen 空间在 Java 8 中被 MetaSpace 替换。 PermSize 和 MaxPermSize JVM 参数被忽略,如果在启动时存在,则会发出警告。

类元数据的大部分分配现在都分配在本机内存之外。* 用于描述类元数据的类已被删除。

旧的 PermGen 和新的 MetaSpace 的主要区别在于,您不必强制定义内存使用上限。您可以让 MetaSpace 空间限制不受限制。因此,当内存使用量增加时,您不会收到 OutOfMemoryError 错误。而是增加保留的本机内存以填满增加的内存使用量。

您可以为 MetaSpace 定义最大空间限制,然后它会抛出 OutOfMemoryError : Metadata space。因此,谨慎地定义此限制很重要,这样我们就可以避免内存浪费。

2021-09-16T02:33:38   回复
IT小君

Oracle 的 Java 8 JVM 实现摆脱了 PermGen 模型,取而代之的是Metaspace

2021-09-16T02:33:38   回复