不能一味加内存解决问题,最好定期检查一下程序对内存的消耗,以避免潜 在的内存溢出。
建议大家使用jvisualvm来监控JVM。(JDK自带,命令行直 接打jvisualvm即可)
一定要设置正确的JVM参数。我建议的JVM参数是:
-Xmx512m -XX:PermSize=128m -XX:MaxPermSize=256m
即:最大512M heap,预留128M的permGen。千万不要把permGen设置得过大,这样会变相减少了heap的内存。
事实上,项目启动之后只需要少于400m 的heap + 不到100m的 permgen 内存.
看下图:
启动完毕之后,heap高峰曾达到400M。然后收缩至280M左右。
PermGen内存大约在100M左右。PermGen不要浪费太多,因为这部 分内存大约等于WAR的大小+大约20%的增长,取决于你使用的framework。
使用过程中,内存也没有消耗过多,一般在400M之下。
备注:
我在Maven Build的JRE和JRE的Default VM Arguments里都设置了,
似乎在后者才有效, 设置如下
-hotspot -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=256m