`

五、IndexReader和IndexWriter的生命周期

 
阅读更多

对于IndexReader而言,反复使用 IndexReader .open打开会有很大的开销,所以一般在整个程序的生命周期中只会打开一个IndexReader,通过这个IndexReader来创建不同的IndexSearcher,如果使用单例模式,可能出现的问题有:
1、当使用Writer修改了索引之后不会更新信息,所以需要使用IndexReader.openIfChange方法操作

 

            if (reader == null) {
                reader = IndexReader.open(directory, false);
            } else {

                         //如果索引改变了,才返回一个reader ,否则返回null
                IndexReader tr = IndexReader.openIfChanged (reader);
                if (tr != null) {
                    reader.close();
                    reader = tr;
                }
            }


对于IndexWriter而言,如果IndexWriter在创建完成之后,没有关闭,需要进行commit操作之后才能提交


writer.commit ();

 

分享到:
评论

相关推荐

    Lucene检索

    它管理着索引的生命周期,并确保数据的一致性。 5. **IndexReader** 和 **Directory**:IndexReader用于读取索引,Directory则像文件系统一样管理索引的存储位置。常见的Directory实现有FSDirectory(文件系统)和...

    lucene4.6例子

    这得益于段合并优化和`NRTManager`的使用,后者管理`IndexReader`的生命周期,确保快速响应新添加的文档。 五、版本对比 Lucene 4.6与5.0的主要差异在于性能优化、新特性和API的改进。5.0引入了新的分析器、更高效...

    Lucene 原理与代码分析完整版.pdf

    - **SearcherManager**:管理IndexReader的生命周期,提供搜索功能。 ### 索引文件格式 Lucene的索引文件采用了一种高效的存储格式,旨在最小化磁盘空间占用并加速数据访问。关键特性包括: - **前缀后缀规则**:...

    全文搜索-Lucene

    通过添加、删除和修改 Document 对象,IndexWriter 可以管理索引的生命周期。 4. **IndexReader** 和 **Directory**: 读取已建立的索引,Directory 表示存储索引的物理位置,如文件系统或内存。 5. **Searcher**: ...

    Luence和ElasticSearch面试准备.docx

    在面试中,了解Elasticsearch的数据模型(如文档、索引、类型和映射)、RESTful API的使用、集群管理和数据生命周期管理等方面的知识是非常重要的。 对于字段的处理,是否分词和索引取决于字段的特性。需要分词的...

    lucene3.6源码

    通过源码,可以理解索引段的生命周期管理。 8. **查询优化** Lucene支持查询树的优化,包括并行化查询执行、短语查询的优化等。`QueryRewriter`和`QueryOptimiser`类在其中起到关键作用。 9. **扩展性** Lucene...

    Lucene简单实例

    2. **IndexWriter**:用于创建和更新索引,它会管理索引的生命周期。 3. **Document**:表示要索引的单个文档,可以包含多个字段,每个字段都有其特定的类型。 4. **Field**:文档中的数据单元,如标题、正文等,...

    lucene分析

    3. IndexWriter:索引写入器负责创建和更新索引,它管理着索引的生命周期,包括添加、删除和优化。 4. IndexReader:索引读取器用于从索引中获取信息,例如查询文档是否存在、获取文档数量等。 5. Searcher:搜索...

    lucene-3.5.0.jar

    - **IndexWriter**:用于创建和更新索引,它管理索引的生命周期,包括添加、删除和修改文档。 - **IndexReader**:用于读取索引,提供搜索操作。 - **IndexSearcher**:执行搜索查询,并返回匹配的Document结果。...

    搜索引擎Lucene_资料

    - **IndexWriter**: 用于创建和更新索引,处理索引生命周期管理。 - **IndexReader**: 读取索引,提供文档和术语的访问接口。 - **IndexSearcher**: 执行查询,返回匹配的文档及其相关度分数。 - **Query**: 查询...

    Lucene.net开发最全文档

    - `IndexWriter`:用于创建和更新索引,管理索引的生命周期。 - `Directory`:存储索引的容器,可以是文件系统或内存中的目录。 - `IndexReader`:读取索引,获取文档信息。 - `IndexSearcher`:执行查询,返回...

Global site tag (gtag.js) - Google Analytics