【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>
最近项目突然出现了“java.lang.OutOfMemoryError: PermGen space”的错误,其实关于 PermGen space 错误的解释,网上已经有很多了,摘录一段
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,
这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen
space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对
PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen
space错误,这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大
量的第三方jar, 其大小超过了jvm默认的大小那么就会产生此错误信息了。
java其实并不推荐大量使用反射来构造对象
很多人都把这个错误的原因,很大程度上都归结于使用了spring hibernate……,因为他们动态产生类(java反射),导致溢出(spring在AOP的时候使用CBLIB会产生很多类,hibernate反射也会产生很多类)
原因是:
原来SUN的JVM把内存分了不同的区,其中一个就是permenter区用来存放用得非常多的类和类描述。本来SUN设计的时候认为这个区域在JVM启动的时候就固定了,但他没有想到现在动态会用得这么广泛。而且这个区域有特殊的垃圾收回机 制,现在的问题是动态加载类到这个区域后,gc根本没办法回收!
解决方法很多,就不贴上了···
个人觉得,出现这个问题的原因,跟这些框架的使用,是存在一定关系的···
关于ORM框架反射的问题,其实应该用泛型+继承,或者泛型工厂模式来实现,而不是无脑反射。
(PS: 如果tomcat运行多个系统,将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少
jar 文档重复占用内存的目的。)
来源:oschina
链接:https://my.oschina.net/u/859156/blog/386114