238

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

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

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

4

6 回答 6

370

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

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

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

元空间的优势

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

元空间调优

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

更改会在未来启用其他优化和功能

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

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

于 2014-03-19T14:55:16.243 回答
118

这是 Java 8 的新特性之一,是JDK 增强提案 122的一部分:

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

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

于 2013-08-20T22:18:34.257 回答
21

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

于 2014-04-30T13:04:02.410 回答
17

Because the PermGen space was removed. Memory management has changed a bit.

java-8-permgen-metaspace

于 2013-08-20T16:00:23.373 回答
13

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

类元数据的大多数分配现在都是从本机内存中分配的。* 用于描述类元数据的类已被删除。

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

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

于 2017-01-17T05:17:42.660 回答
10

Oracle's JVM implementation for Java 8 got rid of the PermGen model and replaced it with Metaspace.

于 2013-08-20T15:59:48.753 回答