Linux上的Java内存使用

前端之家收集整理的这篇文章主要介绍了Linux上的Java内存使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在运行 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的六千万.

我失踪了什么

解决方法

尝试使用增量垃圾收集器,使用-Xincgc命令行选项. 在整个GC工作中,它的攻击力更小,并且具有特别的快乐的小异常:它实际上将一些未使用的内存移回操作系统,与默认和其他GC选择不同! 这使得JVM消耗的内存少得多,如果在一台机器上运行多个JVM,这是非常好的.以某些表现为代价 – 但您可能不会注意到.这个incgc似乎是一个小秘密,因为没有人带来它…它已经在eons(90年代).

猜你在找的Linux相关文章