如果IndexSearcher调用空RAMDirectory,则为IndexNotFoundException

# some java_imports here
index = RAMDirectory.new
IndexWriter.new(index,StandardAnalyzer.new(Version::LUCENE_30),IndexWriter::MaxFieldLength::UNLIMITED )
IndexSearcher.new(index)

生成

NativeException: org.apache.lucene.index.IndexNotFoundException: no segments* file found in org.apache.lucene.store.RAMDirectory@668c640e lockFactory=org.apache.lucene.store.SingleInstanceLockFactory@afd07bb: files: []

为什么会这样?

解决方法

IndexSearcher需要一个特殊的目录结构,它找不到因为没有写入段(当你向IndexWriter添加文档时,它们在内存中排队,当使用的内存量达到给定的阈值或者commit()时这些内存中的数据结构被刷新到磁盘,导致Lucene称之为段.

您需要做的是通过在打开IndexSearcher之前调用commit来明确地创建一个段.

index = RAMDirectory.new
writer = IndexWriter.new(index,IndexWriter::MaxFieldLength::UNLIMITED)
writer.commit()
IndexSearcher.new(index)

此外,在Lucene 3.4中不推荐使用此IndexWriter构造函数,您应该使用IndexWriterConfig为IndexWriter配置:

iwConfig = IndexWriterConfig.new(Version::LUCENE_34,StandardAnalyzer.new(Version::LUCENE_34))
writer = IndexWriter.new(index,iwConfig)

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...