java.lang.OutOfMemoryError: PermGen space有效解决方法
背景
某线上项目运行一段时间就崩溃,查看服务器日志,提示java.lang.OutOfMemoryError: PermGen space
原因分析
通过 jmap -heap pid 命令查看项目内存分配,结果如下:
Perm Generation分配大小82.0MB,项目运行时容量不足,该区域使用率达到100%,同时导致cpu占用率高达600%
Perm Generation: 永久带,用于存放静态文件,如今Java类、方法等。持久代对垃圾回收没有显著影响,但是有些应用可能动态生成或者调用一些class,例如Hibernate等,在这种时候需要设置一个比较大的持久代空间来存放这些运行过程中新增的类。
注意:
JDK1.8中,永久代已经从java堆中移除,String直接存放在堆中,类的元数据存储在meta space中,meta space占用外部内存,不占用堆内存。可以说,在java8的新版本中,持久代已经更名为了元空间(meta space)。
解决方案
服务器中修改catalina.sh文件配置
JAVA_OPTS="$JAVA_OPTS -server -Xmx1024M -Xms512m -XX:MaxNewSize=256m -XX:PermSize=512m -XX:MaxPermSize=512m"
参考文章:
https://blog.****.net/yrpting/article/details/52859721
http://outofmemory.cn/c/java-outOfMemoryError