本文整理匯總了Java中org.apache.lucene.index.IndexWriterConfig.setOpenMode方法的典型用法代碼示例。如果您正苦於以下問題:Java IndexWriterConfig.setOpenMode方法的具體用法?Java IndexWriterConfig.setOpenMode怎麽用?Java IndexWriterConfig.setOpenMode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.lucene.index.IndexWriterConfig
的用法示例。
在下文中一共展示了IndexWriterConfig.setOpenMode方法的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;
}
示例2: process
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
@Override
public void process(ProcessingContext<Corpus> ctx, Corpus corpus) throws ModuleException {
try (KeywordAnalyzer kwa = new KeywordAnalyzer()) {
IndexWriterConfig writerConfig = new IndexWriterConfig(Version.LUCENE_36, kwa);
writerConfig.setOpenMode(append ? OpenMode.CREATE_OR_APPEND : OpenMode.CREATE);
try (Directory dir = FSDirectory.open(indexDir)) {
try (IndexWriter writer = new IndexWriter(dir, writerConfig)) {
AlvisDBIndexerResolvedObjects resObj = getResolvedObjects();
Logger logger = getLogger(ctx);
EvaluationContext evalCtx = new EvaluationContext(logger);
for (ADBElements.Resolved ent : resObj.elements) {
ent.indexElements(logger, writer, evalCtx, corpus);
}
}
}
catch (IOException e) {
rethrow(e);
}
}
}
示例3: LuceneIndex
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
* Constructor for LuceneIndex
*
* @param dataDirectory Path to the directory to create an index directory within.
* @throws IndexException
*/
public LuceneIndex(Path dataDirectory) throws IndexException {
//TODO: Check to make sure directory is read/writable
path = dataDirectory.resolve(INDEXDIR);
try {
dir = FSDirectory.open(path);
analyzer = new StandardAnalyzer();
IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
iwc.setOpenMode(OpenMode.CREATE_OR_APPEND);
writer = new IndexWriter(dir, iwc);
reader = DirectoryReader.open(writer, false);
searcher = new IndexSearcher(reader);
parser = new QueryParser(IndexDocumentAdapter.FIELD_SEARCH, analyzer);
} catch (IOException e) {
LOG.error(e.getLocalizedMessage());
throw new IndexException(e);
}
}
示例4: InMemoryIndex
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public InMemoryIndex(Map<String,String> id2Text){
Analyzer analyzer = new EnglishAnalyzer();
IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
try {
IndexWriter writer = new IndexWriter(directory, iwc);
for (String id:id2Text.keySet()) {
Document doc=new Document();
doc.add(new StringField("id", id, Field.Store.YES));
doc.add(new TextField("content", id2Text.get(id), Field.Store.YES));
writer.addDocument(doc);
}
writer.close();
} catch (IOException e) {
e.printStackTrace();
}
}
示例5: index
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
* Indexing documents using provided Analyzer
*
* @param create to decide create new or append to previous one
* @throws IOException
*/
public void index(final Boolean create, List<Document> documents, Analyzer analyzer) throws IOException {
final Directory dir = FSDirectory.open(Paths.get(pathToIndexFolder));
final IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
if (create) {
// Create a new index in the directory, removing any
// previously indexed documents:
iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
}
else {
// Add new documents to an existing index:
iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
}
final IndexWriter w = new IndexWriter(dir, iwc);
w.addDocuments(documents);
w.close();
}
示例6: createIndexQ
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public static void createIndexQ(List<CQAResult> QASetList, Directory dir) {
System.out.println("Creating Questions Index");
IndexWriterConfig iwc = new IndexWriterConfig(ANALYZER.getVersion(), ANALYZER);
iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
try {
IndexWriter writer = new IndexWriter(dir, iwc);
int id = 0; //XXX seq_id
for (CQAResult qaSet : QASetList) {
Document doc = new Document();
if (qaSet.subject == null) {
id++;
continue;
}
doc.add(new IntField(QID, id++, Field.Store.YES));
doc.add(new TextField(BEST_ANSWER_FIELD, qaSet.subject, Field.Store.NO));
doc.add(new TextField(Q_DESCRIPTION, qaSet.content, Field.Store.NO));
writer.addDocument(doc);
}
writer.close();
} catch (IOException e) {
e.printStackTrace();
}
}
示例7: getIndexWriter
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
* 獲取writer
*
* @return
* @throws IOException
*/
protected static IndexWriter getIndexWriter() throws IOException {
if (null != indexWriter) {
return indexWriter;
} else {
// 防止並發
synchronized (IndexUtil.class) {
// 初始化writer
IndexWriterConfig config = new IndexWriterConfig(Version.LUCENE_35,
new StandardAnalyzer(Version.LUCENE_35));
// 每次都重新創建
config.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
indexWriter = new IndexWriter(directory, config);
}
return indexWriter;
}
}
示例8: createWriter
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public void createWriter(String indexPath){
/*
The indexPath specifies where to create the index
*/
// I am can imagine that there are lots of ways to create indexers -
// We could add in some parameters to customize its creation
try {
Directory dir = FSDirectory.open(Paths.get(indexPath));
System.out.println("Indexing to directory '" + indexPath + "'...");
IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
iwc.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
writer = new IndexWriter(dir, iwc);
} catch (IOException e){
e.printStackTrace();
System.exit(1);
}
}
示例9: 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);
}
示例10: Indexer
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
* Create or open a document index
*
* @param indexRoot The parent directory inside which the index lives.
* @param appendIfExists If true, the index will be opened for appending new documents.
* @throws IOException
*/
public Indexer(String indexRoot, boolean appendIfExists) throws IOException {
Path indexRootPath = Paths.get(indexRoot);
Analyzer analyzer = getAnalyzer();
Directory mainIndexDir = FSDirectory.open(getMainIndexPath(indexRootPath));
IndexWriterConfig mainIndexWriterConfig = new IndexWriterConfig(analyzer);
if (appendIfExists) {
mainIndexWriterConfig.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
} else {
mainIndexWriterConfig.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
}
indexWriter = new IndexWriter(mainIndexDir, mainIndexWriterConfig);
}
示例11: main
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public static void main(String args[]) throws Exception {
initLoggers(Level.ERROR);
RedisDirectory DIR = new RedisDirectory(REDIS_HOST, REDIS_PORT, REDIS_PASSWORD);
DIR.init();
long t1 = System.currentTimeMillis();
try {
Analyzer analyzer = new StandardAnalyzer();
IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
iwc.setOpenMode(OpenMode.CREATE_OR_APPEND);
IndexWriter iw = new IndexWriter(DIR, iwc);
Path docDir = Paths
.get("/Users/btnguyen/Workspace/Apps/Apache-Cassandra-2.1.8/javadoc/");
indexDocs(iw, docDir);
iw.commit();
iw.close();
} finally {
DIR.destroy();
}
long t2 = System.currentTimeMillis();
System.out.println("Finished in " + (t2 - t1) / 1000.0 + " sec");
}
示例12: main
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
public static void main(String args[]) throws Exception {
initLoggers(Level.INFO);
RedisDirectory DIR = new RedisDirectory(REDIS_HOST, REDIS_PORT, REDIS_PASSWORD);
DIR.init();
long t1 = System.currentTimeMillis();
try {
Analyzer analyzer = new StandardAnalyzer();
IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
iwc.setOpenMode(OpenMode.CREATE_OR_APPEND);
IndexWriter iw = new IndexWriter(DIR, iwc);
Document doc = new Document();
doc.add(new StringField("id", "thanhnb", Field.Store.YES));
doc.add(new TextField("name", "Nguyen Ba Thanh", Field.Store.NO));
iw.updateDocument(new Term("id", "thanhnb"), doc);
iw.commit();
iw.close();
} finally {
DIR.destroy();
}
long t2 = System.currentTimeMillis();
System.out.println("Finished in " + (t2 - t1) / 1000.0 + " sec");
}
示例13: openWriter
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
private IndexWriter openWriter(Conf conf, boolean create) throws IOException {
File indexDir = new File(conf.getEsaIndexDir());
indexDir.mkdirs();
System.out.println("Create index on " + indexDir.getAbsolutePath());
Directory fsDirectory = FSDirectory.open(indexDir);
IndexWriterConfig config = new IndexWriterConfig(Conf.LUCENE_VERSION, new ESAAnalyzer(conf));
config.setSimilarity(new ESASimilarity());
if (create) {
// Create a new index in the directory, removing any
// previously indexed documents:
config.setOpenMode(IndexWriterConfig.OpenMode.CREATE);
} else {
// Add new documents to an existing index:
config.setOpenMode(IndexWriterConfig.OpenMode.CREATE_OR_APPEND);
}
return new IndexWriter(fsDirectory, config);
}
示例14: 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();
}
}
示例15: create
import org.apache.lucene.index.IndexWriterConfig; //導入方法依賴的package包/類
/**
* Creates an empty collection to get it up and running
*/
public synchronized void create() throws IOException {
setDirectory();
if ( directory.listAll().length > 2 )
throw new IOException( "directory not empty; possible collection already present" );
IndexWriterConfig iwc = new IndexWriterConfig( AnalyzerFactory.get(language) );
iwc.setOpenMode( OpenMode.CREATE );
indexwriter = new IndexWriter(directory, iwc);
indexwriter.commit();
indexwriter.close();
indexwriter = null;
// throw an openbd.create file in there so we know when it was created
created = System.currentTimeMillis();
File touchFile = new File( collectionpath, "openbd.created" );
Writer fw = new FileWriter( touchFile );
fw.close();
}