springmvc hibernate jvm permGen Space

一个人想着一个人 提交于 2020-01-07 18:08:04

【推荐】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 文档重复占用内存的目的。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!