我正在运行
Java应用程序服务器,它们都运行在CentOS 5.5
Linux之上的最新版本的Tomcat 6和Sun的Java 6.每个服务器运行多个Tomcat实例.
我设置-Xmx450m -XX:MaxPermSize = 192m参数来控制堆和permgen将增长多大.这些设置适用于所有Java应用程序服务器中的所有Tomcat实例,共计约70个Tomcat实例.
这是Psi-probe报告的其中一个Tomcat实例的典型内存使用情况
Eden = 13M
Survivor = 1.5M
Perm Gen = 122M
Code Cache = 19M
Old Gen = 390M
Total = 537M
然而,CentOS在707M(根据RSS)报告了该特定进程的RAM使用情况,这使得170M的RAM未被下载.
我知道JVM本身和一些依赖库必须加载到内存中,所以我决定启动pmap -d来找出它们的内存占用.
根据我的计算,约17M.
接下来有一个Java线程堆栈,在32位JVM for Linux上,每个线程是320k.
再次,我使用Psi-probe来计算该特定JVM上的线程数,总共为129个线程.所以129 320k = 42M
我读过NIO在堆外使用内存,但我们在应用程序中不使用NIO.
所以在这里我已经计算出了我所想到的一切.而我只占到了“失踪”170M的六千万.
我失踪了什么