當前位置: 首頁>>代碼示例>>Java>>正文


Java SearcherManager類代碼示例

本文整理匯總了Java中org.apache.lucene.search.SearcherManager的典型用法代碼示例。如果您正苦於以下問題:Java SearcherManager類的具體用法?Java SearcherManager怎麽用?Java SearcherManager使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


SearcherManager類屬於org.apache.lucene.search包,在下文中一共展示了SearcherManager類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: wrapSearcher

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public Engine.Searcher wrapSearcher(String source, Engine.Searcher engineSearcher, IndexSearcher searcher, SearcherManager manager) {
    final AssertingIndexSearcher assertingIndexSearcher = newSearcher(source, searcher, manager);
    assertingIndexSearcher.setSimilarity(searcher.getSimilarity(true));
    // pass the original searcher to the super.newSearcher() method to make sure this is the searcher that will
    // be released later on. If we wrap an index reader here must not pass the wrapped version to the manager
    // on release otherwise the reader will be closed too early. - good news, stuff will fail all over the place if we don't get this right here
    AssertingSearcher assertingSearcher = new AssertingSearcher(assertingIndexSearcher, engineSearcher, shardId, logger) {
        @Override
        public void close() {
            try {
                searcherCloseable.remove(this);
            } finally {
                super.close();
            }
        }
    };
    searcherCloseable.add(assertingSearcher, engineSearcher.source());
    return assertingSearcher;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:20,代碼來源:MockEngineSupport.java

示例2: readLastCommittedSegmentInfos

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
/**
 * Read the last segments info from the commit pointed to by the searcher manager
 */
protected static SegmentInfos readLastCommittedSegmentInfos(final SearcherManager sm, final Store store) throws IOException {
    IndexSearcher searcher = sm.acquire();
    try {
        IndexCommit latestCommit = ((DirectoryReader) searcher.getIndexReader()).getIndexCommit();
        return Lucene.readSegmentInfos(latestCommit);
    } catch (IOException e) {
        // Fall back to reading from the store if reading from the commit fails
        try {
            return store.readLastCommittedSegmentsInfo();
        } catch (IOException e2) {
            e2.addSuppressed(e);
            throw e2;
        }
    } finally {
        sm.release(searcher);
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:21,代碼來源:Engine.java

示例3: readLastCommittedSegmentInfos

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
/**
 * Read the last segments info from the commit pointed to by the searcher manager
 */
protected static SegmentInfos readLastCommittedSegmentInfos(final SearcherManager sm, final Store store) throws IOException {
    IndexSearcher searcher = sm.acquire();
    try {
        IndexCommit latestCommit = ((DirectoryReader) searcher.getIndexReader()).getIndexCommit();
        return Lucene.readSegmentInfos(latestCommit);
    } catch (IOException e) {
        // Fall back to reading from the store if reading from the commit fails
        try {
            return store. readLastCommittedSegmentsInfo();
        } catch (IOException e2) {
            e2.addSuppressed(e);
            throw e2;
        }
    } finally {
        sm.release(searcher);
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:21,代碼來源:Engine.java

示例4: on

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
@Transactional
@Listen
public void on(EntityRemoved event) {
	if (event.getEntity() instanceof Project) {
		dao.doAfterCommit(new Runnable() {

			@Override
			public void run() {
				synchronized (searcherManagers) {
					Long projectId = event.getEntity().getId();						
					SearcherManager searcherManager = searcherManagers.remove(projectId);
					if (searcherManager != null) {
						try {
							searcherManager.close();
						} catch (IOException e) {
							Throwables.propagate(e);
						}
					}
				}
			}
			
		});
	}
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:25,代碼來源:DefaultSearchManager.java

示例5: LuceneService

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public LuceneService(final SearcherManager searcherManager,
                     final Analyzer analyzer,
                     final LuceneQueryTransformer queryTransformer,
                     final LuceneDocumentTransformer<QR> documentTransformer,
                     final SortTypeFactory sortTypeFactory,
                     final Integer maxSearchResults) {
    this.searcherManager = searcherManager;
    this.analyzer = analyzer;
    this.queryTransformer = queryTransformer;
    this.documentTransformer = documentTransformer;
    this.sortTypeFactory = sortTypeFactory;
    this.maxSearchResults = maxSearchResults;
    this.fieldDocSerializer = new StandardFieldDocSerializer();

    Validate.notNull(this.searcherManager);
    Validate.notNull(this.queryTransformer);
    Validate.notNull(this.documentTransformer);
    Validate.notNull(this.sortTypeFactory);
    Validate.notNull(this.maxSearchResults);
}
 
開發者ID:bbende,項目名稱:tripod,代碼行數:21,代碼來源:LuceneService.java

示例6: findWave

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
@Override
public Digest findWave(WaveId waveId, ParticipantId viewer) {
  TermQuery query = new TermQuery(new Term(IndexCondition.Field.WAVE_ID.toString(), waveId.serialise()));
  SearcherManager searcherManager = nrtManager.getSearcherManager(true);
  IndexSearcher indexSearcher = searcherManager.acquire();
  try {
    TopDocs hints = indexSearcher.search(query, 1);
    if (hints.totalHits != 0) {
      ScoreDoc hint = hints.scoreDocs[0];
      return parseDigest(indexSearcher.doc(hint.doc), null);
    }
  } catch (IOException ex) {
    LOG.log(Level.SEVERE, "Search wave " + waveId.serialise() + " failed", ex);
  }
  return null;
}
 
開發者ID:jorkey,項目名稱:Wiab.pro,代碼行數:17,代碼來源:LuceneSearchImpl.java

示例7: AnalyzingInfixSuggester

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
/** Create a new instance, loading from a previously built
 *  AnalyzingInfixSuggester directory, if it exists.  This directory must be
 *  private to the infix suggester (i.e., not an external
 *  Lucene index).  Note that {@link #close}
 *  will also close the provided directory.
 *
 *  @param minPrefixChars Minimum number of leading characters
 *     before PrefixQuery is used (default 4).
 *     Prefixes shorter than this are indexed as character
 *     ngrams (increasing index size but making lookups
 *     faster).
 */
public AnalyzingInfixSuggester(Version matchVersion, Directory dir, Analyzer indexAnalyzer, Analyzer queryAnalyzer, int minPrefixChars) throws IOException {

  if (minPrefixChars < 0) {
    throw new IllegalArgumentException("minPrefixChars must be >= 0; got: " + minPrefixChars);
  }

  this.queryAnalyzer = queryAnalyzer;
  this.indexAnalyzer = indexAnalyzer;
  this.matchVersion = matchVersion;
  this.dir = dir;
  this.minPrefixChars = minPrefixChars;

  if (DirectoryReader.indexExists(dir)) {
    // Already built; open it:
    writer = new IndexWriter(dir,
                             getIndexWriterConfig(matchVersion, getGramAnalyzer(), IndexWriterConfig.OpenMode.APPEND));
    searcherMgr = new SearcherManager(writer, true, null);
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:32,代碼來源:AnalyzingInfixSuggester.java

示例8: refreshIfNeeded

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
@Override
protected SearcherAndTaxonomy refreshIfNeeded(SearcherAndTaxonomy ref) throws IOException {
  // Must re-open searcher first, otherwise we may get a
  // new reader that references ords not yet known to the
  // taxonomy reader:
  final IndexReader r = ref.searcher.getIndexReader();
  final IndexReader newReader = DirectoryReader.openIfChanged((DirectoryReader) r);
  if (newReader == null) {
    return null;
  } else {
    DirectoryTaxonomyReader tr = TaxonomyReader.openIfChanged(ref.taxonomyReader);
    if (tr == null) {
      ref.taxonomyReader.incRef();
      tr = ref.taxonomyReader;
    } else if (taxoWriter != null && taxoWriter.getTaxonomyEpoch() != taxoEpoch) {
      IOUtils.close(newReader, tr);
      throw new IllegalStateException("DirectoryTaxonomyWriter.replaceTaxonomy was called, which is not allowed when using SearcherTaxonomyManager");
    }

    return new SearcherAndTaxonomy(SearcherManager.getSearcher(searcherFactory, newReader), tr);
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:23,代碼來源:SearcherTaxonomyManager.java

示例9: LuceneFiler

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public LuceneFiler(@Nonnull Filer delegate, @Nonnull Config config) throws IOException {
	super(delegate);

	String path = config.getString("index.path");
	maxAge = config.getTime("index.maxAge", "-1");
	double maxMergeMb = config.getDouble("index.maxMergeMb", 4);
	double maxCachedMb = config.getDouble("index.maxCacheMb", 64);
	long targetMaxStale = config.getTime("index.targetMaxStale", "5s");
	long targetMinStale = config.getTime("index.targetMinStale", "1s");

	Directory dir = FSDirectory.open(new File(path).toPath());
	NRTCachingDirectory cachingDir = new NRTCachingDirectory(dir, maxMergeMb, maxCachedMb);
	IndexWriterConfig writerConfig = new IndexWriterConfig(null);
	writerConfig.setOpenMode(OpenMode.CREATE_OR_APPEND);

	writer = new TrackingIndexWriter(new IndexWriter(cachingDir, writerConfig));
	manager = new SearcherManager(writer.getIndexWriter(), true, new SearcherFactory());
	thread = new ControlledRealTimeReopenThread<>(writer, manager, targetMaxStale, targetMinStale);
	thread.start();
}
 
開發者ID:lithiumtech,項目名稱:flow,代碼行數:21,代碼來源:LuceneFiler.java

示例10: setDAG

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
@Override
public void setDAG(DirectedAcyclicGraph directedAcyclicGraph) {
	super.setDAG(directedAcyclicGraph);

	// Connect to the Lucene DB
	try {
		Analyzer analyser = new KeywordAnalyzer();
		IndexWriterConfig config = new IndexWriterConfig(analyser);
		config.setOpenMode(OpenMode.CREATE_OR_APPEND);
		Path path = DAGModule.moduleFile(directedAcyclicGraph.rootDir_,
				INDEX_FOLDER).toPath();
		Directory directory = FSDirectory.open(path);
		// Directory directory = new RAMDirectory();
		writer_ = new IndexWriter(directory, config);

		// Searching
		parser_ = new QueryParser(LOWERCASE_FIELD, analyser);
		manager_ = new SearcherManager(writer_, true, new SearcherFactory());
	} catch (Exception e) {
		e.printStackTrace();
	}
}
 
開發者ID:Effervex,項目名稱:DagYo,代碼行數:23,代碼來源:NodeAliasLuceneModule.java

示例11: refreshIfNeeded

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
@Override
protected SearcherAndTaxonomy refreshIfNeeded(SearcherAndTaxonomy ref) throws IOException {
  // Must re-open searcher first, otherwise we may get a
  // new reader that references ords not yet known to the
  // taxonomy reader:
  final IndexReader r = ref.searcher.getIndexReader();
  final IndexReader newReader = DirectoryReader.openIfChanged((DirectoryReader) r);
  if (newReader == null) {
    return null;
  } else {
    DirectoryTaxonomyReader tr = TaxonomyReader.openIfChanged(ref.taxonomyReader);
    if (tr == null) {
      ref.taxonomyReader.incRef();
      tr = ref.taxonomyReader;
    } else if (taxoWriter.getTaxonomyEpoch() != taxoEpoch) {
      IOUtils.close(newReader, tr);
      throw new IllegalStateException("DirectoryTaxonomyWriter.replaceTaxonomy was called, which is not allowed when using SearcherTaxonomyManager");
    }

    return new SearcherAndTaxonomy(SearcherManager.getSearcher(searcherFactory, newReader), tr);
  }
}
 
開發者ID:jimaguere,項目名稱:Maskana-Gestor-de-Conocimiento,代碼行數:23,代碼來源:SearcherTaxonomyManager.java

示例12: LuceneRetrievalService

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public LuceneRetrievalService(final SearcherManager searcherManager,
                              final Analyzer analyzer,
                              final LuceneQueryTransformer queryTransformer,
                              final LuceneDocumentTransformer<E> documentTransformer,
                              final SortTypeFactory sortTypeFactory) {
    this.searcherManager = searcherManager;
    this.analyzer = analyzer;
    this.queryTransformer = queryTransformer;
    this.documentTransformer = documentTransformer;
    this.sortTypeFactory = sortTypeFactory;
    Validate.notNull(this.searcherManager);
    Validate.notNull(this.queryTransformer);
    Validate.notNull(this.documentTransformer);
    Validate.notNull(this.sortTypeFactory);
}
 
開發者ID:bbende,項目名稱:tripod,代碼行數:16,代碼來源:LuceneRetrievalService.java

示例13: newSearcher

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public AssertingIndexSearcher newSearcher(String source, IndexSearcher searcher, SearcherManager manager) throws EngineException {
    IndexReader reader = searcher.getIndexReader();
    IndexReader wrappedReader = reader;
    assert reader != null;
    if (reader instanceof DirectoryReader && mockContext.wrapReader) {
        wrappedReader = wrapReader((DirectoryReader) reader);
    }
    // this executes basic query checks and asserts that weights are normalized only once etc.
    final AssertingIndexSearcher assertingIndexSearcher = new AssertingIndexSearcher(mockContext.random, wrappedReader);
    assertingIndexSearcher.setSimilarity(searcher.getSimilarity(true));
    assertingIndexSearcher.setQueryCache(filterCache);
    assertingIndexSearcher.setQueryCachingPolicy(filterCachingPolicy);
    return assertingIndexSearcher;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:15,代碼來源:MockEngineSupport.java

示例14: ShadowEngine

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public ShadowEngine(EngineConfig engineConfig)  {
    super(engineConfig);
    if (engineConfig.getRefreshListeners() != null) {
        throw new IllegalArgumentException("ShadowEngine doesn't support RefreshListeners");
    }
    SearcherFactory searcherFactory = new EngineSearcherFactory(engineConfig);
    final long nonexistentRetryTime = engineConfig.getIndexSettings().getSettings()
            .getAsTime(NONEXISTENT_INDEX_RETRY_WAIT, DEFAULT_NONEXISTENT_INDEX_RETRY_WAIT)
            .getMillis();
    try {
        DirectoryReader reader = null;
        store.incRef();
        boolean success = false;
        try {
            if (Lucene.waitForIndex(store.directory(), nonexistentRetryTime)) {
                reader = ElasticsearchDirectoryReader.wrap(DirectoryReader.open(store.directory()), shardId);
                this.searcherManager = new SearcherManager(reader, searcherFactory);
                this.lastCommittedSegmentInfos = readLastCommittedSegmentInfos(searcherManager, store);
                success = true;
            } else {
                throw new IllegalStateException("failed to open a shadow engine after" +
                        nonexistentRetryTime + "ms, " +
                        "directory is not an index");
            }
        } catch (Exception e) {
            logger.warn("failed to create new reader", e);
            throw e;
        } finally {
            if (success == false) {
                IOUtils.closeWhileHandlingException(reader);
                store.decRef();
            }
        }
    } catch (IOException ex) {
        throw new EngineCreationFailureException(shardId, "failed to open index reader", ex);
    }
    logger.trace("created new ShadowEngine");
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:39,代碼來源:ShadowEngine.java

示例15: ShadowEngine

import org.apache.lucene.search.SearcherManager; //導入依賴的package包/類
public ShadowEngine(EngineConfig engineConfig)  {
    super(engineConfig);
    SearcherFactory searcherFactory = new EngineSearcherFactory(engineConfig);
    final long nonexistentRetryTime = engineConfig.getIndexSettings()
            .getAsTime(NONEXISTENT_INDEX_RETRY_WAIT, DEFAULT_NONEXISTENT_INDEX_RETRY_WAIT)
            .getMillis();
    try {
        DirectoryReader reader = null;
        store.incRef();
        boolean success = false;
        try {
            if (Lucene.waitForIndex(store.directory(), nonexistentRetryTime)) {
                reader = ElasticsearchDirectoryReader.wrap(DirectoryReader.open(store.directory()), shardId);
                this.searcherManager = new SearcherManager(reader, searcherFactory);
                this.lastCommittedSegmentInfos = readLastCommittedSegmentInfos(searcherManager, store);
                success = true;
            } else {
                throw new IllegalStateException("failed to open a shadow engine after" +
                        nonexistentRetryTime + "ms, " +
                        "directory is not an index");
            }
        } catch (Throwable e) {
            logger.warn("failed to create new reader", e);
            throw e;
        } finally {
            if (success == false) {
                IOUtils.closeWhileHandlingException(reader);
                store.decRef();
            }
        }
    } catch (IOException ex) {
        throw new EngineCreationFailureException(shardId, "failed to open index reader", ex);
    }
    logger.trace("created new ShadowEngine");
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:36,代碼來源:ShadowEngine.java


注:本文中的org.apache.lucene.search.SearcherManager類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。