Lucene.Net writing/reading synchronization

前端 未结 2 900
不知归路
不知归路 2020-12-31 13:03
  1. Could I write (with IndexWriter) new documents into index while it is opened for reading (with IndexReader)? Or must I close reading befor

相关标签:
2条回答
  • 2020-12-31 13:44

    As I found in this mail list

    Lucene.NET is thread-safe. So you can share the same instance of IndexWriter or IndexSearcher among threads. Using a write-lock, it also hinders a second IndexWriter instance to be opened with the same index.

    As I see I can write and read separatly; I'll check it;)

    0 讨论(0)
  • 2020-12-31 13:51

    You may have any amount of readers/searchers opened at any time, but only one writer. This is enforced by a directory specific lock, usually involving a file named "write.lock".

    Readers open snapshots, and writers adds more data to the index. Readers need to be opened or reopened (IndexReader.Reopen) after your writer has commited (IndexWriter.Commit) the data for it to be seen, unless you're working with near-realtime-searches. This involves a special reader returned from (IndexWriter.GetReader) which will be able to see content up to the time the call to GetReader was executed. It also means that the reader may see data that will never be commited due to application logic calling IndexWriter.Rollback.

    Searchers uses readers, so identical limitations on these. (Unlimited number of them, can only see what's already commited, unless based on a near-realtime reader.)

    Lucene is thread-safe, and best practices is to share readers and searchers between several threads, while checking that IndexReader.IsCurrent() == true. You could have a background thread running that reopens the reader once it detects changes, create a new searcher, and then let the main threads use it. This would also allow you to prewarm any FieldCache you use to increase search speed when once the new searcher is in place.

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