当我使用以下配置在Hotspot VM上运行我的Java应用程序时:-Xms2048m,-Xmx2048m,jmap输出:
Heap Configuration:
MinHeapFreeRatio = 40
MaxHeapFreeRatio = 70
MaxHeapSize = 2147483648 (2048.0MB)
NewSize = 1310720 (1.25MB)
MaxNewSize = 17592186044415 MB
OldSize = 5439488 (5.1875MB)
NewRatio = 2
SurvivorRatio = 8
PermSize = 21757952 (20.75MB)
MaxPermSize = 85983232 (82.0MB)
Heap Usage:
PS Young Generation
Eden Space:
capacity = 706740224 (674.0MB)
used = 364788568 (347.88948822021484MB)
free = 341951656 (326.11051177978516MB)
51.61565107124849% used
From Space:
capacity = 4587520 (4.375MB)
used = 1900560 (1.8125152587890625MB)
free = 2686960 (2.5624847412109375MB)
41.428920200892854% used
To Space:
capacity = 4456448 (4.25MB)
used = 0 (0.0MB)
free = 4456448 (4.25MB)
0.0% used
...
令我困惑的是为什么伊甸园空间和两个幸存者空间的能力不遵守公式
eden/(s0+s1) = SurvivorRatio
但是当我添加另一个jvm选项-Xmn500m时,jmap输出似乎是合理的,即容量严格遵守公式
我希望这会得到更多关注......确实你是对的(这不是一个答案 - 但是评论太久了)
当我做:
java -XX:+PrintFlagsFinal | grep SurvivorRatio
uintx InitialSurvivorRatio = 8
显然这是8.但是在测试时它的表现更像是6(我无法重现你用jdk-8看到的巨大差异)。
以下是使用-Xmx2048m -Xms2048m运行时的相关部分
PS Young Generation
Eden Space:
capacity = 537395200 (512.5MB)
....
From Space:
capacity = 89128960 (85.0MB)
....
To Space:
capacity = 89128960 (85.0MB)
那是:
512/85 = 6
只要我使用相同的-Xmx2048m -Xms2048m运行相同的代码,但添加默认值:-XX:SurvivorRatio = 8;输出是:
PS Young Generation
Eden Space:
capacity = 573046784 (546.5MB)
....
From Space:
capacity = 71303168 (68.0MB)
....
To Space:
capacity = 71303168 (68.0MB)
546.5 / 68 = 8.
您正在设置的-Xmn也是如此。这很奇怪!我没有改变SurvivorRatio
的值 - 它仍然是相同的默认值8。
似乎内部有一些检查是否正在设置与SurvivorRatio
的计算相关的标志并应用不同的策略(我希望我知道这些内在函数,但没有运气)。
还有男孩!我试着找到这些吗?我确实发现了一些提示,但不是直接回答,如this或this(特别是评论)。我做了一个:
grep -R "SurvivorRatio" .
在hotspot
内部来源本地,仍然没有暗示所发生的所有结果。
我此时唯一合理的解释是,除非指定任何与SurvivorRatio
相关的参数;将选择一个默认值(不一定是java -XX:+PrintFlagsFinal
报告的那个),但是中间的东西,接近那个。如果是这种情况,则应在文件中明确说明;否则在我的世界中,这是一个很小的文档错误。