Package org.apache.lucene.search
Class SearcherManager
- All Implemented Interfaces:
Closeable,AutoCloseable
Utility class to safely share
IndexSearcher instances across multiple
threads, while periodically reopening. This class ensures each searcher is
closed only once all threads have finished using it.
Use ReferenceManager.acquire() to obtain the current searcher, and ReferenceManager.release(G) to
release it, like this:
IndexSearcher s = manager.acquire();
try {
// Do searching, doc retrieval, etc. with s
} finally {
manager.release(s);
}
// Do not use s after this!
s = null;
In addition you should periodically call ReferenceManager.maybeRefresh(). While it's
possible to call this just before running each query, this is discouraged
since it penalizes the unlucky queries that do the reopen. It's better to use
a separate background thread, that periodically calls maybeReopen. Finally,
be sure to call ReferenceManager.close() once you are done.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.apache.lucene.search.ReferenceManager
ReferenceManager.RefreshListener -
Constructor Summary
ConstructorsConstructorDescriptionSearcherManager(IndexWriter writer, boolean applyAllDeletes, SearcherFactory searcherFactory) Creates and returns a new SearcherManager from the givenIndexWriter.SearcherManager(Directory dir, SearcherFactory searcherFactory) Creates and returns a new SearcherManager from the givenDirectory. -
Method Summary
Modifier and TypeMethodDescriptionstatic IndexSearchergetSearcher(SearcherFactory searcherFactory, IndexReader reader) Expert: creates a searcher from the providedIndexReaderusing the providedSearcherFactory.booleanReturnstrueif no changes have occured since this searcher ie.Methods inherited from class org.apache.lucene.search.ReferenceManager
acquire, addListener, close, maybeRefresh, maybeRefreshBlocking, release, removeListener
-
Constructor Details
-
SearcherManager
public SearcherManager(IndexWriter writer, boolean applyAllDeletes, SearcherFactory searcherFactory) throws IOException Creates and returns a new SearcherManager from the givenIndexWriter.- Parameters:
writer- the IndexWriter to open the IndexReader from.applyAllDeletes- Iftrue, all buffered deletes will be applied (made visible) in theIndexSearcher/DirectoryReader. Iffalse, the deletes may or may not be applied, but remain buffered (in IndexWriter) so that they will be applied in the future. Applying deletes can be costly, so if your app can tolerate deleted documents being returned you might gain some performance by passingfalse. SeeDirectoryReader.openIfChanged(DirectoryReader, IndexWriter, boolean).searcherFactory- An optionalSearcherFactory. Passnullif you don't require the searcher to be warmed before going live or other custom behavior.- Throws:
IOException- if there is a low-level I/O error
-
SearcherManager
Creates and returns a new SearcherManager from the givenDirectory.- Parameters:
dir- the directory to open the DirectoryReader on.searcherFactory- An optionalSearcherFactory. Passnullif you don't require the searcher to be warmed before going live or other custom behavior.- Throws:
IOException- if there is a low-level I/O error
-
-
Method Details
-
isSearcherCurrent
Returnstrueif no changes have occured since this searcher ie. reader was opened, otherwisefalse.- Throws:
IOException- See Also:
-
getSearcher
public static IndexSearcher getSearcher(SearcherFactory searcherFactory, IndexReader reader) throws IOException Expert: creates a searcher from the providedIndexReaderusing the providedSearcherFactory. NOTE: this decRefs incoming reader on throwing an exception.- Throws:
IOException
-