【发布时间】:2011-03-26 06:04:09
【问题描述】:
我们有生产 Tomcat (6.0.18) 服务器,它使用以下设置运行:
-server -Xms7000M -Xmx7000M -Xss128k -XX:+UseFastAccessorMethods
-XX:+HeapDumpOnOutOfMemoryError -Dcom.sun.management.jmxremote.port=7009
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false -verbose:gc -XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=/opt/apache-tomcat-6.0.18/conf/logging.properties
-agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=n
-Djava.endorsed.dirs=/opt/apache-tomcat-6.0.18/endorsed
-classpath :/opt/apache-tomcat-6.0.18/bin/bootstrap.jar
java version "1.6.0_12"
Java(TM) SE Runtime Environment (build 1.6.0_12-b04)
Java HotSpot(TM) 64-Bit Server VM (build 11.2-b01, mixed mode)
经过一段时间的工作,我们得到(通过 JConsole)以下内存消耗:
Current heap size: 3 034 233 kbytes
Maximum heap size: 6 504 832 kbytes
Committed memory: 6 504 832 kbytes
Pending finalization: 0 objects
Garbage collector: Name = 'PS MarkSweep', Collections = 128, Total time spent = 16 minutes
Garbage collector: Name = 'PS Scavenge', Collections = 1 791, Total time spent = 17 minutes
Operating System: Linux 2.6.26-2-amd64
Architecture: amd64
Number of processors: 2
Committed virtual memory: 9 148 856 kbytes
Total physical memory: 8 199 684 kbytes
Free physical memory: 48 060 kbytes
Total swap space: 19 800 072 kbytes
Free swap space: 15 910 212 kbytes
问题是为什么我们有很多已提交的虚拟内存?请注意,最大堆大小约为 7Gb(正如预期的那样,因为 Xmx=7G)。
顶部显示如下:
31413 root 18 -2 8970m 7.1g 39m S 90 90.3 351:17.87 java
为什么 JVM 需要额外的 2Gb!虚拟内存?我可以像在 JRockit http://blogs.oracle.com/jrockit/2009/02/why_is_my_jvm_process_larger_t.html 中那样获得非堆内存分配吗?
编辑 1:Perm 为 36M。
【问题讨论】: