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


Java IndexWriterConfig.setCodec方法代碼示例

本文整理匯總了Java中org.apache.lucene.index.IndexWriterConfig.setCodec方法的典型用法代碼示例。如果您正苦於以下問題:Java IndexWriterConfig.setCodec方法的具體用法?Java IndexWriterConfig.setCodec怎麽用?Java IndexWriterConfig.setCodec使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.lucene.index.IndexWriterConfig的用法示例。


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

示例1: getIndexWriterConfig

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private IndexWriterConfig getIndexWriterConfig(boolean create) {
    final IndexWriterConfig iwc = new IndexWriterConfig(engineConfig.getAnalyzer());
    iwc.setCommitOnClose(false); // we by default don't commit on close
    iwc.setOpenMode(create ? IndexWriterConfig.OpenMode.CREATE : IndexWriterConfig.OpenMode.APPEND);
    iwc.setIndexDeletionPolicy(deletionPolicy);
    // with tests.verbose, lucene sets this up: plumb to align with filesystem stream
    boolean verbose = false;
    try {
        verbose = Boolean.parseBoolean(System.getProperty("tests.verbose"));
    } catch (Exception ignore) {
    }
    iwc.setInfoStream(verbose ? InfoStream.getDefault() : new LoggerInfoStream(logger));
    iwc.setMergeScheduler(mergeScheduler);
    MergePolicy mergePolicy = config().getMergePolicy();
    // Give us the opportunity to upgrade old segments while performing
    // background merges
    mergePolicy = new ElasticsearchMergePolicy(mergePolicy);
    iwc.setMergePolicy(mergePolicy);
    iwc.setSimilarity(engineConfig.getSimilarity());
    iwc.setRAMBufferSizeMB(engineConfig.getIndexingBufferSize().getMbFrac());
    iwc.setCodec(engineConfig.getCodec());
    iwc.setUseCompoundFile(true); // always use compound on flush - reduces # of file-handles on refresh
    return iwc;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:25,代碼來源:InternalEngine.java

示例2: assertCompressionEquals

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private void assertCompressionEquals(Mode expected, Codec actual) throws Exception {
    Directory dir = newDirectory();
    IndexWriterConfig iwc = newIndexWriterConfig(null);
    iwc.setCodec(actual);
    IndexWriter iw = new IndexWriter(dir, iwc);
    iw.addDocument(new Document());
    iw.commit();
    iw.close();
    DirectoryReader ir = DirectoryReader.open(dir);
    SegmentReader sr = (SegmentReader) ir.leaves().get(0).reader();
    String v = sr.getSegmentInfo().info.getAttribute(Lucene50StoredFieldsFormat.MODE_KEY);
    assertNotNull(v);
    assertEquals(expected, Mode.valueOf(v));
    ir.close();
    dir.close();
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:17,代碼來源:CodecTests.java

示例3: initializeIndexBuilder

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void initializeIndexBuilder() throws Exception {
    // Create a new index directory and writer to index a triples file.
    // Raise an error if an index already exists, so we don't accidentally overwrite it.
    String indexDir = getIndexDirectoryName();
    if ((new File(indexDir)).isDirectory())
        throw new IOException("Index directory already exists, remove it before indexing");

    indexDirectory = FSDirectory.open(Paths.get(indexDir));
    IndexWriterConfig iwc = new IndexWriterConfig(getIndexAnalyzer());

    // we always create a new index from scratch:
    iwc.setOpenMode(OpenMode.CREATE);
    iwc.setCodec(new Lucene54Codec(Mode.BEST_SPEED));          // the default
    //iwc.setCodec(new Lucene54Codec(Mode.BEST_COMPRESSION));  // slower, but better compression

    indexWriter = new IndexWriter(indexDirectory, iwc);
    indexAnalyzer = getIndexAnalyzer();

    if (INDEX_PREDICATES) printlnProg("Indexing individual predicates");
    if (INDEX_TEXT) printlnProg("Indexing combined predicate text values");
    if (INDEX_LANGUAGE) printlnProg("Indexing predicates for language(s): " + supportedLanguages);
}
 
開發者ID:isoboroff,項目名稱:basekb-search,代碼行數:23,代碼來源:FreebaseIndexer.java

示例4: testBasic

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testBasic() throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(makeIDField("id0", 100));
  w.addDocument(doc);
  doc = new Document();
  doc.add(makeIDField("id1", 110));
  w.addDocument(doc);
  IndexReader r = w.getReader();
  IDVersionSegmentTermsEnum termsEnum = (IDVersionSegmentTermsEnum) r.leaves().get(0).reader().fields().terms("id").iterator(null);
  assertTrue(termsEnum.seekExact(new BytesRef("id0"), 50));
  assertTrue(termsEnum.seekExact(new BytesRef("id0"), 100));
  assertFalse(termsEnum.seekExact(new BytesRef("id0"), 101));
  assertTrue(termsEnum.seekExact(new BytesRef("id1"), 50));
  assertTrue(termsEnum.seekExact(new BytesRef("id1"), 110));
  assertFalse(termsEnum.seekExact(new BytesRef("id1"), 111));
  r.close();

  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:25,代碼來源:TestIDVersionPostingsFormat.java

示例5: testMoreThanOneDocPerIDWithUpdates

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMoreThanOneDocPerIDWithUpdates() throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(makeIDField("id", 17));
  w.addDocument(doc);
  doc = new Document();
  doc.add(makeIDField("id", 17));
  // Replaces the doc we just indexed:
  w.updateDocument(new Term("id", "id"), doc);
  w.commit();
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:17,代碼來源:TestIDVersionPostingsFormat.java

示例6: testMoreThanOneDocPerIDWithDeletes

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMoreThanOneDocPerIDWithDeletes() throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(makeIDField("id", 17));
  w.addDocument(doc);
  w.deleteDocuments(new Term("id", "id"));
  doc = new Document();
  doc.add(makeIDField("id", 17));
  w.addDocument(doc);
  w.commit();
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:17,代碼來源:TestIDVersionPostingsFormat.java

示例7: testMissingPositions

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMissingPositions() throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(newStringField("id", "id", Field.Store.NO));
  try {
    w.addDocument(doc);
    w.commit();
    fail("didn't hit expected exception");
  } catch (IllegalArgumentException iae) {
    // expected
  }
           
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:19,代碼來源:TestIDVersionPostingsFormat.java

示例8: testInvalidPayload

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testInvalidPayload() throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(new StringAndPayloadField("id", "id", new BytesRef("foo")));
  try {
    w.addDocument(doc);
    w.commit();
    fail("didn't hit expected exception");
  } catch (IllegalArgumentException iae) {
    // expected
  }
           
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:19,代碼來源:TestIDVersionPostingsFormat.java

示例9: testMoreThanOneDocPerIDWithDeletesAcrossSegments

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMoreThanOneDocPerIDWithDeletesAcrossSegments() throws IOException {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(makeIDField("id", 17));
  w.addDocument(doc);
  w.commit();
  doc = new Document();
  doc.add(makeIDField("id", 17));
  // Replaces the doc we just indexed:
  w.updateDocument(new Term("id", "id"), doc);
  w.forceMerge(1);
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:18,代碼來源:TestIDVersionPostingsFormat.java

示例10: testMoreThanOnceInSingleDoc

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMoreThanOnceInSingleDoc() throws IOException {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(makeIDField("id", 17));
  doc.add(makeIDField("id", 17));
  try {
    w.addDocument(doc);
    w.commit();
    fail("didn't hit expected exception");
  } catch (IllegalArgumentException iae) {
    // expected
  }
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:19,代碼來源:TestIDVersionPostingsFormat.java

示例11: doTestMixedPostings

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private void doTestMixedPostings(Codec codec) throws Exception {
  Directory dir = newDirectory();
  IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random()));
  iwc.setCodec(codec);
  RandomIndexWriter iw = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  FieldType ft = new FieldType(TextField.TYPE_NOT_STORED);
  // turn on vectors for the checkindex cross-check
  ft.setStoreTermVectors(true);
  ft.setStoreTermVectorOffsets(true);
  ft.setStoreTermVectorPositions(true);
  Field idField = new Field("id", "", ft);
  Field dateField = new Field("date", "", ft);
  doc.add(idField);
  doc.add(dateField);
  for (int i = 0; i < 100; i++) {
    idField.setStringValue(Integer.toString(random().nextInt(50)));
    dateField.setStringValue(Integer.toString(random().nextInt(100)));
    iw.addDocument(doc);
  }
  iw.close();
  dir.close(); // checkindex
}
 
開發者ID:europeana,項目名稱:search,代碼行數:24,代碼來源:TestPerFieldPostingsFormat2.java

示例12: newConfig

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private IndexWriterConfig newConfig(final Analyzer analyzer) {
    final IndexWriterConfig config = new IndexWriterConfig(analyzer);
    final Codec codec = new Lucene62Codec() {
        @Override
        public PostingsFormat getPostingsFormatForField(String field) {
            if (field.equals("id")) {
                return PostingsFormat.forName("Memory");
            } else {
                return PostingsFormat.forName("Lucene50");
            }
        }
    };
    config.setCodec(codec);

    return config;
}
 
開發者ID:kiegroup,項目名稱:appformer,代碼行數:17,代碼來源:DirectoryFactory.java

示例13: newIndexWriterConfig

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
protected IndexWriterConfig newIndexWriterConfig(Random random) {
  final IndexWriterConfig indexWriterConfig = LuceneTestCase.newIndexWriterConfig(random, LuceneTestCase.TEST_VERSION_CURRENT, new MockAnalyzer(random));
  //TODO can we randomly choose a doc-values supported format?
  if (needsDocValues())
    indexWriterConfig.setCodec( TestUtil.alwaysDocValuesFormat(new Lucene410DocValuesFormat()));;
  return indexWriterConfig;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:8,代碼來源:SpatialTestCase.java

示例14: getIndexWriterConfig

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/** Override this to customize index settings, e.g. which
 *  codec to use. */
protected IndexWriterConfig getIndexWriterConfig(Version matchVersion, Analyzer indexAnalyzer, IndexWriterConfig.OpenMode openMode) {
  IndexWriterConfig iwc = new IndexWriterConfig(matchVersion, indexAnalyzer);
  iwc.setCodec(new Lucene410Codec());
  iwc.setOpenMode(openMode);

  // This way all merged segments will be sorted at
  // merge time, allow for per-segment early termination
  // when those segments are searched:
  iwc.setMergePolicy(new SortingMergePolicy(iwc.getMergePolicy(), SORT));

  return iwc;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:15,代碼來源:AnalyzingInfixSuggester.java

示例15: testMissingPayload

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void testMissingPayload() throws Exception {
  Directory dir = newDirectory();

  // MockAnalyzer minus maybePayload else it sometimes stuffs in an 8-byte payload!
  Analyzer a = new Analyzer() {
      @Override
      public TokenStreamComponents createComponents(String fieldName, Reader reader) {
        MockTokenizer tokenizer = new MockTokenizer(reader, MockTokenizer.WHITESPACE, true, 100);
        tokenizer.setEnableChecks(true);
        MockTokenFilter filt = new MockTokenFilter(tokenizer, MockTokenFilter.EMPTY_STOPSET);
        return new TokenStreamComponents(tokenizer, filt);
      }
    };
  IndexWriterConfig iwc = newIndexWriterConfig(a);
  iwc.setCodec(TestUtil.alwaysPostingsFormat(new IDVersionPostingsFormat()));
  RandomIndexWriter w = new RandomIndexWriter(random(), dir, iwc);
  Document doc = new Document();
  doc.add(newTextField("id", "id", Field.Store.NO));
  try {
    w.addDocument(doc);
    w.commit();
    fail("didn't hit expected exception");
  } catch (IllegalArgumentException iae) {
    // expected
  }
           
  w.close();
  dir.close();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:30,代碼來源:TestIDVersionPostingsFormat.java


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