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


Java IndexWriterConfig.setRAMBufferSizeMB方法代碼示例

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


在下文中一共展示了IndexWriterConfig.setRAMBufferSizeMB方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的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: prepareIndex

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void prepareIndex() throws IOException {
    File globalWFMDIr = new File(Util.GTPM_INDEX_DIR);
    if (!globalWFMDIr.exists()) {
        Util.createDirs(Util.GTPM_INDEX_DIR);
    }
    KeywordAnalyzer keywordAnalyzer = new KeywordAnalyzer();
    IndexWriterConfig wfmIndexWriterConfig = new IndexWriterConfig(Version.LUCENE_46, keywordAnalyzer);
    wfmIndexWriterConfig.setOpenMode(OpenMode.CREATE_OR_APPEND);
    wfmIndexWriterConfig.setRAMBufferSizeMB(1024);

    logger.info("PREPARE INDEX");
    try {
        wfmIndexWriter = new IndexWriter(FSDirectory.open(new File(Util.GTPM_INDEX_DIR)), wfmIndexWriterConfig);
        wfmIndexWriter.commit();
        wfmIndexer = new DocumentMaker(wfmIndexWriter);
    } catch (IOException e) {
        e.printStackTrace();
    }
}
 
開發者ID:Mondego,項目名稱:SourcererCC,代碼行數:20,代碼來源:WordFrequencyStore.java

示例3: testSampler

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
 * Uses the sampler aggregation to find the minimum value of a field out of the top 3 scoring documents in a search.
 */
public void testSampler() throws IOException {
    TextFieldType textFieldType = new TextFieldType();
    textFieldType.setIndexAnalyzer(new NamedAnalyzer("foo", AnalyzerScope.GLOBAL, new StandardAnalyzer()));
    MappedFieldType numericFieldType = new NumberFieldMapper.NumberFieldType(NumberFieldMapper.NumberType.LONG);
    numericFieldType.setName("int");

    IndexWriterConfig indexWriterConfig = newIndexWriterConfig();
    indexWriterConfig.setMaxBufferedDocs(100);
    indexWriterConfig.setRAMBufferSizeMB(100); // flush on open to have a single segment with predictable docIds
    try (Directory dir = newDirectory();
            IndexWriter w = new IndexWriter(dir, indexWriterConfig)) {
        for (long value : new long[] {7, 3, -10, -6, 5, 50}) {
            Document doc = new Document();
            StringBuilder text = new StringBuilder();
            for (int i = 0; i < value; i++) {
                text.append("good ");
            }
            doc.add(new Field("text", text.toString(), textFieldType));
            doc.add(new SortedNumericDocValuesField("int", value));
            w.addDocument(doc);
        }

        SamplerAggregationBuilder aggBuilder = new SamplerAggregationBuilder("sampler")
                .shardSize(3)
                .subAggregation(new MinAggregationBuilder("min")
                        .field("int"));
        try (IndexReader reader = DirectoryReader.open(w)) {
            assertEquals("test expects a single segment", 1, reader.leaves().size());
            IndexSearcher searcher = new IndexSearcher(reader);
            Sampler sampler = searchAndReduce(searcher, new TermQuery(new Term("text", "good")), aggBuilder, textFieldType,
                    numericFieldType);
            Min min = sampler.getAggregations().get("min");
            assertEquals(5.0, min.getValue(), 0);
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:40,代碼來源:SamplerAggregatorTests.java

示例4: FbEntityIndexer

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public FbEntityIndexer(String namefile, String outputDir, String indexingStrategy) throws IOException {

    if (!indexingStrategy.equals("exact") && !indexingStrategy.equals("inexact"))
      throw new RuntimeException("Bad indexing strategy: " + indexingStrategy);

    IndexWriterConfig config =  new IndexWriterConfig(Version.LUCENE_44 , indexingStrategy.equals("exact") ? new KeywordAnalyzer() : new StandardAnalyzer(Version.LUCENE_44));
    config.setOpenMode(OpenMode.CREATE);
    config.setRAMBufferSizeMB(256.0);
    indexer = new IndexWriter(new SimpleFSDirectory(new File(outputDir)), config);

    this.nameFile = namefile;
  }
 
開發者ID:cgraywang,項目名稱:TextHIN,代碼行數:13,代碼來源:FbEntityIndexer.java

示例5: CreateIndex

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public CreateIndex(String srcDir, String indexDir) throws IOException {
	this.srcDirName = srcDir;
	sentenceTokenizer = new SentenceTokenizer(new BufferedReader(
			new StringReader("DUMMY")));

	Directory d = new MMapDirectory(new File(indexDir));
	Analyzer a = new TreeAnalyzer(new LRDP(LRDP.PhysicalPayloadFormat.BYTE1111));
	IndexWriterConfig c = new IndexWriterConfig(Version.LUCENE_42, a);
	c.setRAMBufferSizeMB(1024);
	writer = new IndexWriter(d, c);
	ft = createFieldType();
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:13,代碼來源:CreateIndex.java

示例6: createIndexWriterConfig

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public IndexWriterConfig createIndexWriterConfig() throws IOException {
  IndexWriterConfig indexWriterConfig = new IndexWriterConfig(Version.LATEST, getIndexAnalyzerInstance());
  indexWriterConfig.setRAMBufferSizeMB(48);

  MergePolicy mergePolicy = getPluginManager().getInstance(LindenConfigBuilder.MERGE_POLICY, MergePolicy.class);
  if (mergePolicy != null) {
    indexWriterConfig.setMergePolicy(mergePolicy);
  }
  LOGGER.info("Merge policy : {}", mergePolicy == null ? "Default" : mergePolicy);

  ConcurrentMergeScheduler cms = new ConcurrentMergeScheduler();
  cms.setMaxMergesAndThreads(8, 1);
  indexWriterConfig.setMergeScheduler(cms);
  return indexWriterConfig;
}
 
開發者ID:XiaoMi,項目名稱:linden,代碼行數:16,代碼來源:LindenConfig.java

示例7: openStreams

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
 * Opens all the needed streams that the engine needs to work properly.
 * 
 * @throws IndexException
 */
private void openStreams() throws IndexException {
	try {
		if (_nativeLocking) {
			_storage = FSDirectory.open(new File(INDEX_DIR), new NativeFSLockFactory(INDEX_DIR));
		} else {
			_storage = FSDirectory.open(new File(INDEX_DIR));
		}

		IndexWriterConfig conf = new IndexWriterConfig(Version.LUCENE_32 ,ANALYZER);
		conf.setMaxBufferedDocs(_maxDocsBuffer);
		conf.setRAMBufferSizeMB(_maxRAMBufferSize);

		_iWriter = new IndexWriter(_storage, conf);
	} catch (IOException e) {
		closeAll();

		throw new IndexException("Unable to initialize the index", e);
	}
}
 
開發者ID:drftpd-ng,項目名稱:drftpd3,代碼行數:25,代碼來源:LuceneEngine.java

示例8: instantiateWriter

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private LuceneIndexWriter instantiateWriter( File directory )
{
    try
    {
        IndexWriterConfig writerConfig = new IndexWriterConfig( type.analyzer );
        writerConfig.setRAMBufferSizeMB( determineGoodBufferSize( writerConfig.getRAMBufferSizeMB() ) );
        Directory luceneDir = getDirectory( directory, identifier );
        return IndexWriterFactories.batchInsert( writerConfig ).create( luceneDir );
    }
    catch ( IOException e )
    {
        throw new RuntimeException( e );
    }
}
 
開發者ID:neo4j-contrib,項目名稱:neo4j-lucene5-index,代碼行數:15,代碼來源:LuceneBatchInserterIndex.java

示例9: create_vocabulary_index

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void create_vocabulary_index(File vocabulary_file) throws IOException{
	File index_dir = new File(_index_dir, "vocab");
	if(index_dir.exists()){
		LOG.info("Vocabulary index already exists in directory '{}'.", index_dir.getAbsolutePath());
		if(_overwrite){
			LOG.info("Overwriting index '{}',", index_dir);
			index_dir.delete();
		}
		else
			return;
	}
	index_dir.mkdirs();
	Analyzer analyzer = new KeywordAnalyzer();
	IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_4_9, analyzer);
	iwc.setOpenMode(OpenMode.CREATE);
	iwc.setRAMBufferSizeMB(1024.0);
	Directory directory = new MMapDirectory(index_dir);
	IndexWriter writer_vocab = new IndexWriter(directory, iwc);

	InputStream in = new FileInputStream(vocabulary_file);
	if(vocabulary_file.getName().endsWith(".gz"))
		in = new GZIPInputStream(in);
	LineIterator iter = new LineIterator(new BufferedReader(new InputStreamReader(in,"UTF-8")));
	Document doc = new Document();
	Field f_word = new StringField("word", "", Field.Store.YES); doc.add(f_word);
	long c = 0;
	while(iter.hasNext()){
		if(++c % 10000 == 0)
			LOG.info("Adding {}'th word.", c);
		String line = iter.next();
		try{
			String word = line.trim();
			f_word.setStringValue(word);
			writer_vocab.addDocument(doc);
		}catch(Exception e){
			LOG.warn("Could not process line '{}' in file '{}', malformed line.", line, vocabulary_file, e);
		}
	}

	writer_vocab.forceMergeDeletes();
	writer_vocab.commit();
	writer_vocab.close();
}
 
開發者ID:tudarmstadt-lt,項目名稱:topicrawler,代碼行數:44,代碼來源:GenerateNgramIndex.java

示例10: init

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
 * Builds a new {@link FSIndex}.
 *
 * @param name
 *            the index name
 * @param mbeanName
 *            the JMX MBean object name
 * @param path
 *            the directory path
 * @param analyzer
 *            the index writer analyzer
 * @param refresh
 *            the index reader refresh frequency in seconds
 * @param ramBufferMB
 *            the index writer RAM buffer size in MB
 * @param maxMergeMB
 *            the directory max merge size in MB
 * @param maxCachedMB
 *            the directory max cache size in MB
 * @param refreshTask
 *            action to be done during refresh
 */
public void init(String name, String mbeanName, Path path, Analyzer analyzer, double refresh, int ramBufferMB,
		int maxMergeMB, int maxCachedMB, Runnable refreshTask) {
	try {

		this.path = path;
		this.name = name;

		// Open or create directory
		FSDirectory fsDirectory = FSDirectory.open(path);
		this.directory = new NRTCachingDirectory(fsDirectory, maxMergeMB, maxCachedMB);

		// Setup index writer
		IndexWriterConfig indexWriterConfig = new IndexWriterConfig(analyzer);
		indexWriterConfig.setRAMBufferSizeMB(ramBufferMB);
		indexWriterConfig.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
		indexWriterConfig.setUseCompoundFile(true);
		indexWriterConfig.setMergePolicy(new TieredMergePolicy());
		this.indexWriter = new IndexWriter(this.directory, indexWriterConfig);

		// Setup NRT search
		SearcherFactory searcherFactory = new SearcherFactory() {
			@Override
			public IndexSearcher newSearcher(IndexReader reader, IndexReader previousReader) {
				if (refreshTask != null) {
					refreshTask.run();
				}
				IndexSearcher searcher = new IndexSearcher(reader);
				searcher.setSimilarity(new NoIDFSimilarity());
				return searcher;
			}
		};
		TrackingIndexWriter trackingWriter = new TrackingIndexWriter(this.indexWriter);
		this.searcherManager = new SearcherManager(this.indexWriter, true, searcherFactory);
		this.searcherReopener = new ControlledRealTimeReopenThread<>(trackingWriter, this.searcherManager, refresh,
				refresh);
		this.searcherReopener.start();

		// Register JMX MBean
		// mbean = new ObjectName(mbeanName);
		// ManagementFactory.getPlatformMBeanServer().registerMBean(service,
		// this.mbean);

	} catch (Exception e) {
		throw new FhirIndexException(e, "Error while creating index %s", name);
	}
}
 
開發者ID:jmiddleton,項目名稱:cassandra-fhir-index,代碼行數:69,代碼來源:LuceneService.java

示例11: initialize

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private void initialize(File indexPath, int kmerSize, boolean minStrandKmer, Similarity similarity, int workerThreads, int ramBufferSize) throws Exception {
    if(!indexPath.exists()) {
        indexPath.mkdirs();
    }
    
    if(indexPath.exists()) {
        cleanUpDirectory(indexPath);
    }
    
    this.indexPath = indexPath;
    this.minStrandKmer = minStrandKmer;
    this.analyzer = new KmerIndexAnalyzer(kmerSize, minStrandKmer);
    Directory dir = new MMapDirectory(this.indexPath.toPath()); 
    IndexWriterConfig config = new IndexWriterConfig(this.analyzer); 
    if(similarity != null) {
        config.setSimilarity(similarity);
    }
    
    this.workerThreads = workerThreads;
    
    if(ramBufferSize > 0) {
        config.setRAMBufferSizeMB(ramBufferSize);
    }
    
    config.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
    this.indexWriter = new IndexWriter(dir, config);
    
    this.executor = new BlockingExecutor(this.workerThreads, this.workerThreads * 2);
    
    for(int i=0;i<this.workerThreads;i++) {
        Document doc = new Document();
        Field filenameField = new StringField(IndexConstants.FIELD_FILENAME, "", Field.Store.YES);
        Field headerField = new StringField(IndexConstants.FIELD_HEADER, "", Field.Store.YES);
        Field sequenceDirectionField = new StringField(IndexConstants.FIELD_SEQUENCE_DIRECTION, "", Field.Store.YES);
        Field taxonTreeField = new StringField(IndexConstants.FIELD_TAXONOMY_TREE, "", Field.Store.YES);
        Field sequenceField = new TextField(IndexConstants.FIELD_SEQUENCE, "", Field.Store.NO);

        doc.add(filenameField);
        doc.add(headerField);
        doc.add(sequenceDirectionField);
        doc.add(taxonTreeField);
        doc.add(sequenceField);
        
        this.freeQueue.offer(doc);
    }
}
 
開發者ID:iychoi,項目名稱:biospectra,代碼行數:47,代碼來源:Indexer.java

示例12: build

import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
 * Construye un índice a partir de una colección de documentos de texto plano.
 * Usando Lucene
 * 
 * @param inputCollectionPath ruta de la carpeta en la que se encuentran los documentos a indexar
 * @param outputIndexPath la ruta de la carpeta en la que almacenar el índice creado
 * @param textParser parser de texto que procesará el texto de los documentos para su indexación
 */
@Override
public void build(String inputCollectionPath, String outputIndexPath, TextParser textParser) {
    
    try {
        
        Directory dir = FSDirectory.open(new File(outputIndexPath));
        Analyzer analyzer = new StandardAnalyzer(Version.LUCENE_31);
        IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_31, analyzer);
        ZipFile zip = new ZipFile(inputCollectionPath);
        Enumeration<? extends ZipEntry> entries = zip.entries();
        
        // Crear o reemplazar un indice 
        iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
        iwc.setRAMBufferSizeMB(512.0);
        IndexWriter writer = new IndexWriter(dir, iwc);

        while (entries.hasMoreElements()) {
            
            ZipEntry entry = entries.nextElement();
            
            // Si es un fichero
            if (!entry.isDirectory()) {
                final String name = entry.getName();
                
                // Y es HTML
                if (name.endsWith(".html") || name.endsWith(".htm")) {
                    
                    // Leer su contenido
                    String html = this.getDocumentText(zip.getInputStream(entry));
                    
                    // Parsearlo
                    String text = textParser.parse(html);
                    
                    // Añadirlo al índice
                    Document doc = new Document();
                    
                    // Nombre (almacenar)
                    Field nameField = new Field("name", name, Field.Store.YES, Field.Index.NOT_ANALYZED_NO_NORMS);
                    doc.add(nameField);
                    
                    // Contenido (no almacenar)
                    Field textField = new Field("content", text, Field.Store.YES, Field.Index.ANALYZED, Field.TermVector.WITH_POSITIONS_OFFSETS);
                    doc.add(textField);
                    
                    writer.addDocument(doc);
                }
            }
        }
        writer.close();

       
    } catch (Exception e) {
        System.out.println("No se pudo acceder a la colección \"" + inputCollectionPath + "\"");
    }
}
 
開發者ID:garnachod,項目名稱:mineria2,代碼行數:64,代碼來源:LuceneIndexing.java


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