2010/1/26 Symeon (Akis) Papadopoulos <papa...@iti.gr>:
> Mattias Persson wrote:
>> Ah, do you make sure you call IndexHits#close() on your results from
>> getNodes(), alternatively iterating over the whole result (in which
>> case it's automatically closed)?
>>
> Actually I'm calling the getSingleNode, thus I have no access on the
> IndexHits object.
Oh ok, then this isn't a problem
>
>
>> See more information at
>> http://components.neo4j.org/neo4j-index/apidocs/index.html
>>
>> Are you using the "index" component btw (artifactId: neo4j-index)?
>>
> Yes.
>
> Is it possible that the problem is caused due to the fact that we
> perform several writes in both the graph and the index and we don't
> commit and that we read in between the transaction commits?
No that shouldn't cause any problems. This looks like a bug then.
Could you give us more information about your code, some snippets
perhaps or a test case which can trigger it again?
>
>
>> 2010/1/26 Symeon (Akis) Papadopoulos <papa...@iti.gr>:
>>
>>> Hi all
>>>
>>> While populating a Neo graph, I got the attached exception
>>> (org.apache.lucene.index.MergePolicy$MergeException. See file for details: I
>>> replaced a local path with [some-local-path]).
>>> My setup is like this: I want to benchmark Neo4j for some operations,
>>> amongst which is graph loading.
>>> So, I try to load graphs of various sizes to Neo4j. Up to size 1M edges the
>>> graphs are loaded without any problem, but then this exception is thrown. I
>>> suspect this has to do with the transaction management in my program, which
>>> is handled by a BatchTxManager (a class written by me, thus highly likely to
>>> be the source of trouble). Does the exception ring any bells? What could I
>>> try out in order to identify the problem?
>>>
>>> Best regards,
>>> Akis
>>>
>>>
>>>
>>> Exception in thread "Lucene Merge Thread #0"
>>> org.apache.lucene.index.MergePolicy$MergeException:
>>> java.io.FileNotFoundException: /[some-local-path]/_4k.cfs (Too many open
>>> files)
>>>        at
>>> org.apache.lucene.index.ConcurrentMergeScheduler.handleMergeException(ConcurrentMergeScheduler.java:351)
>>>        at
>>> org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.run(ConcurrentMergeScheduler.java:315)
>>> Caused by: java.io.FileNotFoundException: /[some-local-path]/_4k.cfs (Too
>>> many open files)
>>>        at java.io.RandomAccessFile.open(Native Method)
>>>        at java.io.RandomAccessFile.<init>(RandomAccessFile.java:233)
>>>        at
>>> org.apache.lucene.store.SimpleFSDirectory$SimpleFSIndexInput$Descriptor.<init>(SimpleFSDirectory.java:78)
>>>        at
>>> org.apache.lucene.store.SimpleFSDirectory$SimpleFSIndexInput.<init>(SimpleFSDirectory.java:108)
>>>        at
>>> org.apache.lucene.store.NIOFSDirectory$NIOFSIndexInput.<init>(NIOFSDirectory.java:94)
>>>        at
>>> org.apache.lucene.store.NIOFSDirectory.openInput(NIOFSDirectory.java:70)
>>>        at
>>> org.apache.lucene.index.CompoundFileReader.<init>(CompoundFileReader.java:70)
>>>        at
>>> org.apache.lucene.index.SegmentReader$CoreReaders.<init>(SegmentReader.java:111)
>>>        at org.apache.lucene.index.SegmentReader.get(SegmentReader.java:638)
>>>        at org.apache.lucene.index.SegmentReader.get(SegmentReader.java:608)
>>>        at
>>> org.apache.lucene.index.IndexWriter$ReaderPool.get(IndexWriter.java:686)
>>>        at
>>> org.apache.lucene.index.IndexWriter.mergeMiddle(IndexWriter.java:4979)
>>>        at org.apache.lucene.index.IndexWriter.merge(IndexWriter.java:4614)
>>>        at
>>> org.apache.lucene.index.ConcurrentMergeScheduler.doMerge(ConcurrentMergeScheduler.java:235)
>>>        at
>>> org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.run(ConcurrentMergeScheduler.java:291)
>>> Exception in thread "main"
>>> org.neo4j.kernel.impl.transaction.TransactionFailureException: Unable to
>>> commit transaction
>>>        at
>>> org.neo4j.kernel.EmbeddedGraphDbImpl$TransactionImpl.finish(EmbeddedGraphDbImpl.java:331)
>>>        at
>>> org.neo4j.util.SimpleBatchTxManager.beginReadOperation(SimpleBatchTxManager.java:94)
>>>        at
>>> graph.implementation.neo.STSGraphNeoImpl.getUserNeo(STSGraphNeoImpl.java:463)
>>>        at
>>> graph.implementation.neo.STSGraphNeoImpl.increaseUserTagFreq(STSGraphNeoImpl.java:824)
>>>        at
>>> graph.benchmark.LoadGraphBenchmark.runRealBenchmark(LoadGraphBenchmark.java:433)
>>>        at
>>> graph.benchmark.LoadGraphBenchmark.main(LoadGraphBenchmark.java:489)
>>> Caused by: java.lang.RuntimeException: Unable to close lucene writer
>>> org.apache.lucene.index.indexwri...@32a4eb93
>>>        at
>>> org.neo4j.index.lucene.LuceneDataSource.removeWriter(LuceneDataSource.java:413)
>>>        at
>>> org.neo4j.index.lucene.LuceneTransaction.doCommit(LuceneTransaction.java:197)
>>>        at
>>> org.neo4j.kernel.impl.transaction.xaframework.XaTransaction.commit(XaTransaction.java:316)
>>>        at
>>> org.neo4j.kernel.impl.transaction.xaframework.XaResourceManager.commit(XaResourceManager.java:399)
>>>        at
>>> org.neo4j.kernel.impl.transaction.xaframework.XaResourceHelpImpl.commit(XaResourceHelpImpl.java:64)
>>>        at
>>> org.neo4j.kernel.impl.transaction.TransactionImpl.doCommit(TransactionImpl.java:514)
>>>        at
>>> org.neo4j.kernel.impl.transaction.TxManager.commit(TxManager.java:573)
>>>        at
>>> org.neo4j.kernel.impl.transaction.TxManager.commit(TxManager.java:543)
>>>        at
>>> org.neo4j.kernel.impl.transaction.TransactionImpl.commit(TransactionImpl.java:102)
>>>        at
>>> org.neo4j.kernel.EmbeddedGraphDbImpl$TransactionImpl.finish(EmbeddedGraphDbImpl.java:316)
>>>        ... 5 more
>>> Caused by: java.io.IOException: directory '/[some-local-path]/resource_id'
>>> exists and is a directory, but cannot be listed: list() returned null
>>>        at org.apache.lucene.store.FSDirectory.listAll(FSDirectory.java:516)
>>>        at org.apache.lucene.store.FSDirectory.listAll(FSDirectory.java:531)
>>>        at
>>> org.apache.lucene.index.IndexFileDeleter.refresh(IndexFileDeleter.java:307)
>>>        at
>>> org.apache.lucene.index.IndexWriter.doFlushInternal(IndexWriter.java:4300)
>>>        at org.apache.lucene.index.IndexWriter.doFlush(IndexWriter.java:4192)
>>>        at org.apache.lucene.index.IndexWriter.flush(IndexWriter.java:4183)
>>>        at
>>> org.apache.lucene.index.IndexWriter.closeInternal(IndexWriter.java:2190)
>>>        at org.apache.lucene.index.IndexWriter.close(IndexWriter.java:2153)
>>>        at org.apache.lucene.index.IndexWriter.close(IndexWriter.java:2117)
>>>        at
>>> org.neo4j.index.lucene.LuceneDataSource.removeWriter(LuceneDataSource.java:409)
>>>        ... 14 more
>>>
>>>
>>> _______________________________________________
>>> Neo mailing list
>>> User@lists.neo4j.org
>>> https://lists.neo4j.org/mailman/listinfo/user
>>>
>>>
>>>
>>
>>
>>
>>
>
> _______________________________________________
> Neo mailing list
> User@lists.neo4j.org
> https://lists.neo4j.org/mailman/listinfo/user
>



-- 
Mattias Persson, [matt...@neotechnology.com]
Neo Technology, www.neotechnology.com
_______________________________________________
Neo mailing list
User@lists.neo4j.org
https://lists.neo4j.org/mailman/listinfo/user

Reply via email to