How to make sure Solr/Lucene won't die with java.lang.OutOfMemoryError?

前端 未结 8 674
失恋的感觉
失恋的感觉 2021-02-04 06:31

I\'m really puzzled why it keeps dying with java.lang.OutOfMemoryError during indexing even though it has a few GBs of memory.

Is there a fundamental reason why it needs

相关标签:
8条回答
  • 2021-02-04 06:40

    Looking at the stack trace, it looks like you are performing a search, and sorting by a field. If you need to sort by a field, internally Lucene needs to load up all the values of all the terms in the field into memory. If the field contains a lot of data, then it is very possible that you may run out of memory.

    0 讨论(0)
  • 2021-02-04 06:46

    a wild guess, the documents you are indexing are very large

    Lucene by default only indexes the first 10,000 terms of a document to avoid OutOfMemory errors, you can overcome this limit see setMaxFieldLength

    Also, you could call optimize() and close as soon as you are done with processing with Indexwriter()

    a definite way is to profile and find the bottleneck =]

    0 讨论(0)
  • 2021-02-04 06:54

    You are using the post.jar to index data? This jar has a bug in solr1.2/1.3 I think (but I don't know the details). Our company has fixed this internally and it should be also fixed in the latest trunk solr1.4/1.5.

    0 讨论(0)
  • 2021-02-04 06:54
    • navigate to C:\Bitnami\solr-4.7.2-0\apache-solr\scripts
    • open up serviceinstall.bat (with notepad++ or another program)
    • Either add or update the following properties:- ++JvmOptions=-Xms1024M ++JvmOptions=-Xmx1024M
      • from the command prompt in that window, run serviceinstall.bat REMOVE
      • then run serviceinstall.bat INSTALL
      • Hope that helpw!
    0 讨论(0)
  • 2021-02-04 06:55

    I was using this Java:

    $ java -version
    java version "1.6.0"
    OpenJDK  Runtime Environment (build 1.6.0-b09)
    OpenJDK 64-Bit Server VM (build 1.6.0-b09, mixed mode)
    

    Which was running out of heap space, but then I upgraded to this Java:

    $ java -version
    java version "1.6.0_24"
    Java(TM) SE Runtime Environment (build 1.6.0_24-b07)
    Java HotSpot(TM) 64-Bit Server VM (build 19.1-b02, mixed mode)
    

    And now it works fine, on a huge dataset, with lots of term facets.

    0 讨论(0)
  • 2021-02-04 06:58

    For me it worked after restarting the Tomcat server.

    0 讨论(0)
提交回复
热议问题