java 内存不足_Java内存不足异常

我在Tomcat中运行

Java Web应用程序.该应用程序使用Quartz框架定期调度cron作业.这个cron工作涉及解析一个4 MB的xml文件,我正在使用JDOM API. xml文件包含大约3600个要解析的节点,因此要在DB中更新数据,我按顺序执行此操作.

在解析了几乎一半的文件后,我的应用程序抛出了内存不足异常.堆栈跟踪是:

Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.OutOfMemoryError: Java heap space

at java.util.Arrays.copyOfRange(Arrays.java:3210)

at java.lang.String.(String.java:216)

at java.lang.StringBuffer.toString(StringBuffer.java:585)

at org.netbeans.lib.profiler.server.ProfilerRuntimeMemory.traceVMObjectAlloc(ProfilerRuntimeMemory.java:170)

at java.lang.Throwable.getStackTraceElement(Native Method)

at java.lang.Throwable.getOurStackTrace(Throwable.java:590)

at java.lang.Throwable.getStackTrace(Throwable.java:582)

at org.apache.juli.logging.DirectJDKLog.log(DirectJDKLog.java:155)

at org.apache.juli.logging.DirectJDKLog.error(DirectJDKLog.java:135)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1603)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1610)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1590)

at java.lang.Thread.run(Thread.java:619)

Exception in thread "*** JFluid Monitor thread ***" java.lang.OutOfMemoryError: Java heap space

at java.util.Arrays.copyOf(Arrays.java:2760)

at java.util.Arrays.copyOf(Arrays.java:2734)

at java.util.Vector.ensureCapacityHelper(Vector.java:226)

at java.util.Vector.add(Vector.java:728)

at org.netbeans.lib.profiler.server.Monitors$SurvGenAndThreadsMonitor.updateSurvGenData(Monitors.java:230)

at org.netbeans.lib.profiler.server.Monitors$SurvGenAndThreadsMonitor.run(Monitors.java:169)

Nov 30, 2009 2:22:05 PM org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor processChildren

SEVERE: Exception invoking periodic operation:

java.lang.OutOfMemoryError: Java heap space

at java.lang.StringCoding$StringEncoder.encode(StringCoding.java:232)

at java.lang.StringCoding.encode(StringCoding.java:272)

at java.lang.String.getBytes(String.java:946)

at java.io.UnixFileSystem.getLastModifiedTime(Native Method)

at java.io.File.lastModified(File.java:826)

at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1175)

at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1269)

at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:296)

at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:118)

at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1337)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1601)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1610)

at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1590)

at java.lang.Thread.run(Thread.java:619)

ERROR [JobRunShell]: Job updateVendorData.quoteUpdate threw an unhandled Exception:

java.lang.OutOfMemoryError: Java heap space

at java.util.Arrays.copyOfRange(Arrays.java:3210)

at java.lang.String.(String.java:216)

at java.lang.StringBuffer.toString(StringBuffer.java:585)

at org.apache.commons.dbcp.PoolingConnection$PStmtKey.hashCode(PoolingConnection.java:296)

at java.util.HashMap.get(HashMap.java:300)

at org.apache.commons.pool.impl.GenericKeyedObjectPool.decrementActiveCount(GenericKeyedObjectPool.java:1085)

at org.apache.commons.pool.impl.GenericKeyedObjectPool.returnObject(GenericKeyedObjectPool.java:882)

at org.apache.commons.dbcp.PoolablePreparedStatement.close(PoolablePreparedStatement.java:80)

at org.apache.commons.dbcp.DelegatingStatement.close(DelegatingStatement.java:168)

at com.netcore.smsapps.stock.db.CompanyDaoImpl.updateCompanyQuote(CompanyDaoImpl.java:173)

at com.netcore.smsapps.stock.vendor.MyirisVendor.readScripQuotes(MyirisVendor.java:159)

at com.netcore.smsapps.stock.update.StockUpdateData.execute(StockUpdateData.java:38)

at org.quartz.core.JobRunShell.run(JobRunShell.java:207)

at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:525)

DEBUG [ExceptionHelper]: Detected JDK support for nested exceptions.

ERROR [ErrorLogger]: Job (updateVendorData.quoteUpdate threw an exception.

org.quartz.SchedulerException: Job threw an unhandled exception. [See nested exception: java.lang.OutOfMemoryError: Java heap space]

at org.quartz.core.JobRunShell.run(JobRunShell.java:216)

at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:525)

Caused by: java.lang.OutOfMemoryError: Java heap space

at java.util.Arrays.copyOfRange(Arrays.java:3210)

at java.lang.String.(String.java:216)

at java.lang.StringBuffer.toString(StringBuffer.java:585)

at org.apache.commons.dbcp.PoolingConnection$PStmtKey.hashCode(PoolingConnection.java:296)

at java.util.HashMap.get(HashMap.java:300)

at org.apache.commons.pool.impl.GenericKeyedObjectPool.decrementActiveCount(GenericKeyedObjectPool.java:1085)

at org.apache.commons.pool.impl.GenericKeyedObjectPool.returnObject(GenericKeyedObjectPool.java:882)

at org.apache.commons.dbcp.PoolablePreparedStatement.close(PoolablePreparedStatement.java:80)

at org.apache.commons.dbcp.DelegatingStatement.close(DelegatingStatement.java:168)

at com.netcore.smsapps.stock.db.CompanyDaoImpl.updateCompanyQuote(CompanyDaoImpl.java:173)

at com.netcore.smsapps.stock.vendor.MyirisVendor.readScripQuotes(MyirisVendor.java:159)

at com.netcore.smsapps.stock.update.StockUpdateData.execute(StockUpdateData.java:38)

at org.quartz.core.JobRunShell.run(JobRunShell.java:207)

这甚至导致我的tomcat崩溃.你能帮我诊断一下这个问题.我甚至已经在Netbeans中启用了相同的分析,但似乎即使崩溃了.我保留了分配给Tomcat的默认内存.是否有任何内存泄漏发生.

我的DB是postgres,JDK是1.6.0_15.

谢谢,

阿米特

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值