gpt4 book ai didi

Java: 'tenured'内存和permgen一样吗?

转载 作者:行者123 更新时间:2023-11-30 06:36:48 24 4
gpt4 key购买 nike

我正在尝试收集有关我们偶尔遇到的问题的信息,在运行几周后,应用程序变慢,工作正常,变慢,工作正常,缓慢和正常工作之间的间隔越来越短,更短。我的理论是,随着时间的推移,我们会更频繁地收集垃圾。另一个关键信息是我们偶尔会遇到 OOM PermGen 问题。

我启用了 verbose:gc,现在可以在 catalina.out 中看到 GC 输出。然而,我认为我需要添加 PrintGCDetails 标志,基于此处的信息:

http://www.oracle.com/technetwork/java/gc-tuning-5-138395.html

启用后一个标志将打印出有关“Tenured”内存收集的信息。问题是,是导致 PermGen 错误的内存,还是有什么不同?如果不同,我如何记录显示 PermGen 空间的信息?

编辑——不幸的是,我无法在此环境中附加任何 jvm 监控工具。

编辑——我添加了上述配置选项,以及一个用于打印终身分配的选项,我得到类似的东西

27.701: [GC 27.701: [ParNew
Desired survivor size 2162688 bytes, new threshold 4 (max 4)
- age 1: 1906560 bytes, 1906560 total
- age 2: 2064 bytes, 1908624 total
- age 3: 5064 bytes, 1913688 total
- age 4: 650368 bytes, 2564056 total
: 35684K->2678K(38336K), 0.0068580 secs] 224179K->191173K(1065664K), 0.0069700 secs] [Times: user=0.01 sys=0.00, real=0.01 secs]

ParNew generation 是 permgen 空间吗?

 (concurrent mode failure): 25387K->31940K(1027328K), 0.2983200 secs] 50714K->31940K(1065664K), [CMS Perm : 35273K->35139K(35392K)], 0.2985210 secs] [Times: user=0.30 sys=0.00, real=0.30 secs] 
(concurrent mode failure): 25356K->31941K(1027328K), 0.3032690 secs] 50861K->31941K(1065664K), [CMS Perm : 35264K->35129K(35392K)], 0.3034800 secs] [Times: user=0.30 sys=0.00, real=0.31 secs]

失败困扰着我。

提前致谢

最佳答案

Tenured 和 PermGen 不一样,不是。它们是相关的,但不是一回事。确切的细节取决于您正在使用的 JVM 中的实现,但是,从您链接的文档中:

“与永久代密切相关的第三代是永久代。永久代是特殊的,因为它保存虚拟机所需的数据来描述在 Java 语言级别不具有等效性的对象。例如,描述类和方法的对象存储在永久代中。”

Interned 字符串和类详细信息等通常存储在 PERM 中,而长期存在的 Java 对象是 TENURED。

这是一篇解释 PermGen(以及如何调整它)的不错的文章:http://blogs.oracle.com/jonthecollector/entry/presenting_the_permanent_generation

关于Java: 'tenured'内存和permgen一样吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4336759/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com