加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-05-24 03:11:26 所属栏目:Java 来源:互联网
导读:我在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来检

我在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将挂起.

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

解决方法

如果垃圾收集线程以100%旋转,则可能是它正在尝试执行垃圾收集,但是没有任何对象可以被收集,因此您处于垃圾收集死亡螺旋中,它一直在尝试运行但无法释放任何记忆.

这可能是因为您的程序中存在内存泄漏,或者因为您没有给vm足够的内存来处理正常使用期间加载的对象数.听起来你有足够的空间来增加堆大小.这可能只会延长您达到死亡螺旋之前的时间,或者它可能会让您进入运行状态.你需要在相当长的一段时间内进行测试,以确保你不仅仅是在推迟不可避免的事情.

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读