执行GC后,为什么分配的永久代的大小会增加?

Ani*_*kur 7 java garbage-collection jvm heap-memory permgen

以下是我从jvisualvm 执行GC后拍摄的快照. 堆统计Permgen统计

第一张图片是Heap stats,第二张图片是perm gen stats.我无法理解我什么时候使用 GC的堆大小减少(如预期的那样)但是永久代的分配大小增加了(尽管使用的permgen大小保持不变).What could be the possible explanation of such behavior?

使用JVM参数

-Xbootclasspath/p:../xyz.jar
-Xbootclasspath/a:../abc.jar
-Djava.endorsed.dirs=../resolver
-Djava.library.path=../framework
-Djavax.management.builder.initial=JBeanServerBuilder
-Djavax.net.ssl.trustStore=../certs
-Dorg.mortbay.log.class=JettyLogger
-Xms128m
-Xmx256m
-Xdebug
-Xnoagent
-Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=2000
Run Code Online (Sandbox Code Playgroud)

注意:出于适当原因,我更改了名称(ex xyz.jar).

JVm信息:

JVM: Java HotSpot(TM) 64-Bit Server VM (23.6-b04, mixed mode)
Java: version 1.7.0_11, vendor Oracle Corporation
Java Home: /home/aniket/jdk1.7.0_11/jre
JVM Flags: <none>
Run Code Online (Sandbox Code Playgroud)

Lea*_*ore 3

  • 内存分配 Heap/Perm/Eden/Young/S1/S2 等空间取决于 GC 使用的底层算法。
  • 上述空间的内存分配未定义为绝对值参数。它们被定义为 JVM 可用的总堆/perm 的比率。
  • 上面两点可能指出,当堆大小发生变化时,所有空间的所有内存分配都会重新评估,以维持定义的比率。

下面的链接将非常有用:

http://www.oracle.com/technetwork/java/javase/gc-tuning-6-140523.html