开发小记
??????? 最近用ssh+dwr开发一个项目,前台采用extjs,却发现运行了一段时间突然spring报错,查看错误发现是java.lang.OutofMemoryError PermGen space。google一下,众说纷纭。
?????? ?很多人说因为spring在AOP时使用CGLIB会动态产生很多类,再加上第三方jar过多,导致jvm内存溢出,修改的办法是加大内存。我考虑到我的应用每个DAO层都有接口和相应实现,不会采用CGLIB,而是JDK的动态代理机制,不会生成代理子类。我按以上办法做,在myeclipse中server选项中的tomcat6.x中输入如下命令:-Xms256m -Xmx512m????? -XX PermMaxSize=256m再次运行发现过了一段时间还是会报错。
?????? 后来仔细检查代码,发现在Struts的某个action中由request得到PrintWriter,调用println()方法后,未执行flush()和close(),将其补充,再次运行,一直没有出错,问题解决!多么愚蠢的错误,有时就是注意不到,而且编译器不会报错!
?????? 我猜想问题可能出在自身的程序里,我们不妨先找自己的问题,看看sql执行完有没有关闭相应语句对象,结果集等。(当然采用spring不需考虑,由ioc容器控制hibernate的sessionfactory),检查是否有flush(),close()。否则可能导致内存溢出。
??????? 还有一点需要考虑,采用ssh的架构时,我们需要引入很多jar包,有些jar可能是重复的,只是版本新旧问题,此时一定要仔细检查,采用其中之一,防止出问题。