我正在尝试了解 visualvm 的输出(需要创建具有相同信息的控制台实用程序),但无法理解-“Used heap”中包含哪些 Java 内存部分?

例如-让我们来:

$ jmap -heap 27200
Attaching to process ID 27200, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 20.45-b01

using thread-local object allocation.
Parallel GC with 4 thread(s)

Heap Configuration:
   MinHeapFreeRatio = 40
   MaxHeapFreeRatio = 70
   MaxHeapSize      = 1073741824 (1024.0MB)
   NewSize          = 1310720 (1.25MB)
   MaxNewSize       = 17592186044415 MB
   OldSize          = 5439488 (5.1875MB)
   NewRatio         = 2
   SurvivorRatio    = 8
   PermSize         = 21757952 (20.75MB)
   MaxPermSize      = 1073741824 (1024.0MB)

Heap Usage:
PS Young Generation
Eden Space:
   capacity = 352452608 (336.125MB)
   used     = 319379152 (304.5836944580078MB)
   free     = 33073456 (31.541305541992188MB)
   90.61619768181713% used
From Space:
   capacity = 2686976 (2.5625MB)
   used     = 2326528 (2.21875MB)
   free     = 360448 (0.34375MB)
   86.58536585365853% used
To Space:
   capacity = 2752512 (2.625MB)
   used     = 0 (0.0MB)
   free     = 2752512 (2.625MB)
   0.0% used
PS Old Generation
   capacity = 715849728 (682.6875MB)
   used     = 253887896 (242.1263656616211MB)
   free     = 461961832 (440.5611343383789MB)
   35.46664698879371% used
PS Perm Generation
   capacity = 185139200 (176.5625MB)
   used     = 126335488 (120.48291015625MB)
   free     = 58803712 (56.07958984375MB)
   68.23810840707965% used

我的建议- visualvm 的“已用堆”是:
Eden Space + From Space + To Space + Old Generation(不包括Perm Generation-因为它显示在其他选项卡上)

这是正确的吗?

最佳答案

我相信您的假设是正确的,该图显示了一个橙色区域,该区域代表为该JVM实例预先分配的总堆空间(即,由-Xmx,-Xms定义),而通常摆动的蓝色区域是实时的监视堆空间,该空间由年轻(伊甸园,幸存者=从&到)和老一代空间组成。

因此,如果您需要从jmap解析信息并将此数据呈现在命令行界面实用程序中,则需要解析包含该信息的所有行(不包括您所指出的“Perm Generation”)。
使用的= 319379152(304.5836944580078MB)

改进工具的建议是提交一份特别报告,重点关注旧一代空间的重大变化,因为这将反映完整的GC周期(自从“世界停止”以来,这比Young区域的周期更为关键。算法会影响您的应用程序的性能),您可以检查此类循环的频率,如果需要更复杂的方法,则可以在完整GC循环的持续时间内解析GC日志。

如果您有兴趣,我会在我的博客中发布有关此内容的文章:
https://marcelorjava.wordpress.com/2011/01/21/logs-do-garbage-collector/

10-04 10:16