Java程序(Tomcat)继续吃内存(RES在顶部)

ing*_*ing 5 java memory-leaks cpu-usage

我在4-cpu和32GB内存64位机器上运行Tomcat(操作系统是CentOS 6.3).我启动Tomcat的Java选项是-server -Xms1024m -Xmx1024m -XX:PermSize=512m -XX:MaxPermSize=512m

开始时,RES仅使用顶部810MB,并且不断增加.在此期间,我运行jmap -J-d64 -histo pID检查Java内存堆,我认为gc工作正常,因为堆峰值为510MB,gc后约为200MB.但是当顶部的RES达到1.1g时,CPU使用率将超过100%并且Tomcat将挂起.

使用jstack pid看转储当CPU使用率是100%,一个名为"虚拟线"线吃掉几乎100%的CPU.我用Google搜索,它是JVM gc线程.所以我的问题是:当gc工作正常时,为什么res会继续增长?我怎么能解决这个问题?谢谢.

dig*_*oel 1

如果垃圾收集线程以 100% 的速度旋转,那么它很可能正在尝试执行垃圾收集,但没有任何对象可以被收集,因此您处于垃圾收集死亡螺旋中,它不断尝试运行但无法释放任何记忆。

发生这种情况可能是因为您的程序中存在内存泄漏,或者因为您没有为虚拟机提供足够的内存来处理常规使用期间加载的对象数量。听起来您有足够的空间来增加堆大小。这可能只会延长你陷入死亡螺旋之前的时间,或者可能会让你进入跑步状态。您需要进行相当长一段时间的测试,以确保您不会只是推迟不可避免的事情。