本文主要是介绍ppm内存溢出问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
ppm内存溢出问题解决
一、发现问题
PPM系统手工下发数据到CRM时。下发10万条,每次2000条分页下发。
时间长了会出现内存溢出。在测试库测试发现,linux的内存占用会上升到40%,然后weblogic抛出错误
# java.lang.OutOfMemoryError: requested 67 bytes for char in /BUILD_AREA/jdk6_05/hotspot/src/share/vm/runtime/sharedRuntime.cpp. Out of swap space?
另外,在weblogic和tomcat下面测试,weblogic下面会出现这个问题,tomcat没有问题。另外把这句代码注释后,问题就不会出现了。Weblogic和tomcat的不同点在于weblogic用了分布式事务,tomcat是开发环境,没有用分布式事务。
二、分析问题
1、JVM参数调优
问题一定是和这个查询语句有关。但是这个SQL查询没有问题,dao也是单例的,对象也是方法内定义的,也不是静态的,应该会被回收:
看了weblogic的启动配置,于是通过打印GC来看一下问题,一开始发现打印的GC是这种格式:
352.403: [GC 352.404: [DefNew: 13487K->737K(14208K), 0.0121280 secs] 84892K->72466K(203264K), 0.0122890 secs] [Times: user=0.01 sys=0.01, real=0.01 secs] |
DefNew代表的意义是串行回收器,而这个应用是大吞吐量的应用,应该是并行回收才对。所以就改成了并行回收。
关于GC日志:http://blog.csdn.net/huangzhaoyang2009/article/details/11860757
关于Jvm内存调优jstat的使用:
http://www.cnblogs.com/jackyrong/archive/2010/01/21/1653163.html
新生代与老生代:http://blog.csdn.net/ustcxjt/article/details/7287430
详细的JVM内存模型、GC收集器:
这篇关于ppm内存溢出问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!