簡體   English   中英

MongoDB的Java堆空間

[英]Java heap space with MongoDB

我使用Tomcat,Eclipse,Java EE,MongoDB。

當我運行連接到mongoDB數據庫並保存一些數據的java程序時,出現此錯誤:

Exception in thread "http-bio-8080-exec-19"
java.lang.OutOfMemoryError: Java heap space
        at java.nio.HeapCharBuffer.<init>(HeapCharBuffer.java:57)
        at java.nio.CharBuffer.allocate(CharBuffer.java:331)
        at com.mongodb.ByteEncoder.<init>(ByteEncoder.java:546)
        at com.mongodb.ByteEncoder.<init>(ByteEncoder.java:48)
        at com.mongodb.ByteEncoder$1.createNew(ByteEncoder.java:79)
        at com.mongodb.ByteEncoder$1.createNew(ByteEncoder.java:76)
        at com.mongodb.util.SimplePool._get(SimplePool.java:140)
        at com.mongodb.util.SimplePool.get(SimplePool.java:106)
        at com.mongodb.util.SimplePool.get(SimplePool.java:95)
        at com.mongodb.ByteEncoder.get(ByteEncoder.java:66)
        at com.mongodb.DBMessage.<init>(DBMessage.java:52)
        at com.mongodb.DBApiLayer$MyCollection.insert(DBApiLayer.java:166)
        at com.mongodb.DBApiLayer$MyCollection.insert(DBApiLayer.java:132)
        at com.mongodb.DBApiLayer$MyCollection.insert(DBApiLayer.java:127)
        at web.ApplicationInterface.doGet(ApplicationInterface.java:125)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
        at org.apache.tomee.catalina.OpenEJBValve.invoke(OpenEJBValve.java:45)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
        at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001)
        at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110),

EDIT

我已經更改了Eclipse允許的內存,但是我仍然遇到相同的問題。

這是導致問題的代碼。

db.requestStart();
try 
{
    coll.insert(doc);
    DBObject err = db.getLastError();
} 
finally 
{
    db.requestDone();
}

PROBLEM SOLVED

MongoDB的版本過舊並且有很多錯誤,我現在使用的是2.8版,現在可以正常工作了,謝謝

嘗試增加堆大小

JVM -- keys
 -Xms<size>        set initial Java heap size
 -Xmx<size>        set maximum Java heap size

嘗試使用-Xmx1024m選項為您的JVM允許更多內存(例如): 如何處理“ java.lang.OutOfMemoryError:Java堆空間”錯誤(64MB堆大小)

您要保存多少數據? 我認為您正在嘗試一次將大量數據存儲到MongoDB。

在“運行配置”中編輯這些內容對於“運行配置”,右鍵單擊項目根目錄->“運行方式”->“運行配置”

在VM參數中添加-Xms <size>和-Xmx <size>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM