`
lijun87
  • 浏览: 267896 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Lucene 的存储结构概述

阅读更多

lucene的检索算法属于索引检索,即用空间来换取时间,对需要检索的文件、字符流进行全文索引,在检索的时候对索引进行快速的检索,得到检索位置,这个位置记录检索词出现的文件路径或者某个关键词。

lucene 在存储它的全文索引结构时,是有层次结构的,这涉及到5个层次:索引(Index);段(Segment);文档(Document);域(Field);词(Term),他们的关系如下图所示:(lucene 索引存储结构概念图)

image

下图是Lucene生成的索引的一个实例,右边是对这5个层次的描述:

 

image

Lucene的索引结构是有层次结构的,主要分以下几个层次:

  • 索引(Index):
    • 一个目录一个索引,在Lucene中一个索引是放在一个文件夹中的。
    • 如左图,同一文件夹中的所有的文件构成一个Lucene索引。
  • 段(Segment):
    • 一个索引可以包含多个段,段与段之间是独立的,添加新文档可以生成新的段,不同的段可以合并。
      在建立索引的时候对性能影响最大的地方就是在将索引写入文件的时候, 所以在具体应用的时候就需要对此加以控制,段(Segment) 就是实现这种控制的。稍后详细描述段(Segment) 的控制策略。
    • 如上图,具有相同前缀文件的属同一个段,图中共两个段 "_0" 和 "_1"。
    • segments.gen和segments_5是段的元数据文件,也即它们保存了段的属性信息。
  • 文档(Document):
    • 文档是我们建索引的基本单位,不同的文档是保存在不同的段中的,一个段可以包含多篇文档。
    • 新添加的文档是单独保存在一个新生成的段中,随着段的合并,不同的文档合并到同一个段中。
  • 域(Field):
    • 一篇文档包含不同类型的信息,可以分开索引,比如标题,时间,正文,作者等,都可以保存在不同的域里。
    • 不同域的索引方式可以不同。
  • 词(Term):
    • 词是索引的最小单位,是经过词法分析和语言处理后的字符串。

 

Lucene的索引结构中,即保存了正向信息,也保存了反向信息。

所谓正向信息:

  • 按层次保存了从索引,一直到词的包含关系:索引(Index) –> 段(segment) –> 文档(Document) –> 域(Field) –> 词(Term)
  • 也即此索引包含了那些段,每个段包含了那些文档,每个文档包含了那些域,每个域包含了那些词。
  • 既然是层次结构,则每个层次都保存了本层次的信息以及下一层次的元信息,也即属性信息,比如一本介绍中国地理的书,应该首先介绍中国地理的概况,以及中国包含多少个省,每个省介绍本省的基本概况及包含多少个市,每个市介绍本市的基本概况及包含多少个县,每个县具体介绍每个县的具体情况。
  • 如上图,包含正向信息的文件有:
    • segments_N保存了此索引包含多少个段,每个段包含多少篇文档。
    • XXX.fnm保存了此段包含了多少个域,每个域的名称及索引方式。
    • XXX.fdx,XXX.fdt保存了此段包含的所有文档,每篇文档包含了多少域,每个域保存了那些信息。
    • XXX.tvx,XXX.tvd,XXX.tvf保存了此段包含多少文档,每篇文档包含了多少域,每个域包含了多少词,每个词的字符串,位置等信息。

所谓反向信息:

  • 保存了词典到倒排表的映射:词(Term) –> 文档(Document)
  • 如上图,包含反向信息的文件有:
    • XXX.tis,XXX.tii保存了词典(Term Dictionary),也即此段包含的所有的词按字典顺序的排序。
    • XXX.frq保存了倒排表,也即包含每个词的文档ID列表。
    • XXX.prx保存了倒排表中每个词在包含此词的文档中的位置。

 

段(Segment) 的控制策略

在建立索引的时候对性能影响最大的地方就是在将索引写入文件的时候, 所以在具体应用的时候就需要对此加以控制: 

Lucene默认情况是每加入10份文档(Document)就从内存往index文件写入并生成一个段(Segment) ,然后每10个段(Segment)就合并成一个段(Segment). 这些控制的变量如下: 

IndexWriter属性 默认值 描述
MergeFactory 10 控制segment合并的频率和大小
MaxMergeDocs Int32.MaxValue 限制每个segment中包含的文档数
MinMergeDocs 10 当内存中的文档达到多少的时候再写入segment

MaxMergeDocs用于控制一个segment文件中最多包含的Document数.比如限制为100的话,即使当前有10个segment也不会合并,因为合并后的segment将包含1000个文档,超过了限制。

MinMergeDocs用于确定一个当内存中文档达到多少的时候才写入文件,该项对segment的数量和大小不会有什么影响,它仅仅影响内存的使用,进一步影响写索引的效率。

 

参考资料:
第三节 Lucene索引文件格式分析
http://hi.baidu.com/hustwk/blog/item/133bd2333f867047ad4b5fd0.html

Lucene学习总结之三:Lucene的索引文件格式(1)
http://www.cnblogs.com/forfuture1978/archive/2009/12/14/1623597.html
Lucene学习总结之三:Lucene的索引文件格式(2)
http://www.cnblogs.com/forfuture1978/archive/2009/12/14/1623599.html

Lucene入门与使用
http://blog.csdn.net/mxz391/archive/2007/05/15/1610140.aspx

Lucene 源代码剖析-4 索引文件结构(1)
http://www.cnblogs.com/eaglet/archive/2009/02/13/1390033.html

开放源代码的全文检索引擎Lucene
http://www.lucene.com.cn/about.htm

Lucene:基于Java的全文检索引擎简介
http://www.chedong.com/tech/lucene.html

Lucene应用架构分析
http://book.51cto.com/art/200807/80198.htm

浅谈Lucene架构——开源搜索架构(二) 
http://swanmsg.blog.sohu.com/112470914.html

lucene.net的索引的建立(三): 建立索引的问题
http://tech.ddvip.com/2008-10/122337481074843.html

 

分享到:
评论

相关推荐

    Lucene 概述视频详解

    1. **索引**:在Lucene中,数据不是直接存储的,而是被转换为一种叫做索引的数据结构。索引是经过分析和分词后的文档内容,使得搜索过程可以快速定位到相关的文档。 2. **文档**:在Lucene中,一个文档可以包含多个...

    非常详细的Lucene文档

    **Lucene 概述** Lucene 是一个开源的全文搜索引擎库,由 Apache 软件基金会维护。它为开发者提供了一套高级的文本检索和分析工具,使得在各种应用程序中实现全文搜索变得简单易行。Lucene 可以被集成到 Java 开发...

    lucene 3.5 官网 源代码

    一、Lucene架构概述 Lucene的架构主要由以下几个关键组件构成: 1. 分析器(Analyzer):负责对输入文本进行预处理,如分词、去除停用词等。 2. 文档(Document):用于存储数据的基本单位,可以包含多个字段(Field...

    Lucene+原理与代码分析完整版

    一、Lucene概述 1.1 全文搜索引擎基础 全文搜索引擎不同于传统的索引数据库,它能够对文本内容进行分析和理解,实现基于关键词的模糊匹配。Lucene正是提供了这样的功能,它包括了分词、索引、查询解析和结果排序等...

    lucene3源码分析

    ### Lucene3源码分析知识点概述 #### 一、全文检索的基本原理 ##### 1. 总论 全文检索系统是一种高效的信息检索技术,能够帮助用户在海量文档中快速找到包含特定关键词的信息。Lucene是Java领域内最受欢迎的全文...

    Lucene 常用功能介绍视频详解

    Lucene的核心数据结构是倒排索引,它允许快速定位包含特定词元的文档。每个词元都有一个对应的“术语表”,记录了包含该词元的所有文档ID和频率信息。 9. **扩展与集成** Lucene是许多开源搜索引擎项目的基础,如...

    lucene-3.0.3-src.zip

    一、Lucene的架构概述 Lucene的核心架构由以下几个关键组件构成: 1. **索引(Index)**:Lucene通过将文本数据转换为倒排索引,实现了快速的全文搜索。倒排索引将每个文档中的词项映射到包含这些词项的文档列表,...

    全文检索原理及Lucene实之搜索

    #### Lucene架构概述 Lucene的架构主要分为索引创建、索引和搜索三个部分。索引创建涉及文档的读取、分词以及索引文件的生成;索引则涉及到索引文件的维护和管理;搜索则是根据用户输入的查询条件从索引中检索出...

    Lucene.Net2.3源码,最新版

    在这个项目中,它可能被用作接口,使得 Lucene.Net 能够利用该库进行索引的压缩和解压缩,从而节省存储空间。 6. **LucenePackage.cs** 这可能是 Lucene.Net 包的封装类,负责组件的组装和管理。在 .NET 中,包...

    lucene-3.6.0

    1. **索引结构**:Lucene采用倒排索引(Inverted Index)结构,将文档中的词项与文档ID关联,大大提高了查询效率。在3.6.0版本中,索引的构建和优化过程更为稳定和高效。 2. **查询处理**:Lucene支持多种查询类型...

    luceneDemo

    **Lucene 概述** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发。它提供了一个可扩展的、高效的文本搜索框架,可以被集成到各种 Java 应用程序中,用于实现复杂的全文检索功能。Lucene 支持索引...

    apache下的lucene教程

    ### Apache Lucene教程知识点概述 #### 一、Apache Lucene简介 - **Lucene定义**:Lucene是一款高性能、全功能的文本搜索引擎库,由Java编写而成,是Apache基金会下的一个开源项目。 - **发展历程**:自1999年由...

    lucene4.10.3

    Lucene采用倒排索引(Inverted Index)结构,为每个唯一的术语建立一个术语表,记录该术语在哪些文档中出现以及出现的位置信息,以加速查询速度。 2.3 索引优化 在4.10.3版本中,Lucene对索引过程进行了优化,包括...

    lucene5.0源码包

    Lucene 5.0的API更加精炼和直观,主要分为几个核心接口:`IndexWriter`用于创建和更新索引,`IndexReader`用于读取索引,`Directory`代表存储索引的物理位置,`Analyzer`处理文本分析,`Query`表示查询条件,`...

    lucene,solr的使用

    #### 一、Lucene概述 Lucene是一款高性能、全功能的文本搜索引擎库,由Java语言编写而成。它能够为应用系统提供强大的全文检索能力,是当前最为流行的开源搜索库之一。由于其高度可定制性及良好的扩展性,在搜索...

    lucene 原理与代码分析

    《Lucene原理与代码分析》深入探讨了几乎最新版本的Lucene的工作机制和代码实现细节,为...以上概述了Lucene的核心原理和代码分析中的关键点,通过深入理解这些内容,开发者能够更好地应用和优化基于Lucene的搜索系统。

    lucene全文搜索

    ### Lucene全文搜索知识点概述 #### 一、全文检索的基本概念及应用场景 1. **全文检索定义**: - 全文检索是指从大量文本信息中快速、准确地查找出包含特定关键词或短语的文档的技术。 - 搜索内容为文本信息(非...

    基于lucene的索引与搜索

    基于Lucene的索引与搜索技术,不仅涉及到数据的高效存储和检索,还包括了文本预处理、分词、相关性排序等多个环节。 第二章 搜索引擎的结构 2.1 系统概述 搜索引擎主要由三部分组成:网络爬虫(也称为网络机器人...

Global site tag (gtag.js) - Google Analytics