`
lzj0470
  • 浏览: 1277587 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

lucene开发搜索引擎的一些经验

阅读更多

中文分词:中文分词在建立中文词时有非常大的作用,建立词库就是在中文分词的基础上进行开发的,然后再对词库进行人工的处理才能得到词库。然后我们再用中文词库建立了一批索引,在这个索引上进行一些搜索,对比原来的索引文件进行的搜索,发现用中文分词的索引比标准分词的索引慢,在不加排序的情况下,标准分词的搜索给1秒左右,中文分词就是2秒,加上了排序后标准分词给为2秒,而中文分词则能达5秒左右,差距相当大,观察后发现两个问题,中文分词后的索引文件较标准分词的索引文件大小多出%1左右,经过研究中文分词慢可能是下面的原因,标准分词是将中文分为单个字,中文字单常用的给为5k左右,不常用的共1w,加上英文单词再加上一些其它词等预计标准分词的词条约有2-3w左右,中文分词将不可识别的词按二分法进行拆分,或是拆成单个字,通过对词库的分析发现,经过中文分词的单词光是baizhan论坛就是13万居多,一共有90w个词,再加上其它论坛的分词,预计总共的分词量将是标准分词的几何级数倍,当搜索同一个词时,标准分词只需在2w个词中查找,中文分词需要在可能是上千万的词条中搜索,效率可想而知。

   排序瓶颈,排序是一个非常占用资源的功能,尤其是在数据量特别多的情况下,排序就显示尤为突出,经过测试发现,排序主要和搜索出的数据量有关,比如说搜索出的数据是1w条和1k条的排序是不一样的,但是和索引文件的数据量关系不大,好搜索100m和1G的关系不大,但是搜索1G的也会慢,这是由于搜索数据量有关,而不是排序的关系,因为排序是在搜索完成后再进行的,是对搜索结果进行了一个遍历。Lucene对不同的分词也有不同的效果,经过测试发现lucene用系统自带的标准分词和简单分词搜索的速度较快,使用了中文分词的速度较慢。

   时间范围搜索,使用的是RangeQuery类进行的,测试时没有问题,但用实际数据进行搜索时出现溢出的情况,通过查阅相关资料知道,RangeQuery最大子查询为1024个,可以任意增大,但付出的代价是性能上的损失,增大到10240时也有溢出的现象,进一步发现可以使用语法的方法实现时间段的搜索,字段:[ start TO end ],而且此方法没有溢出,不抛出异常,效快,经过测试发现,时间节省百分之五十,在此要说明的是BooleanQuery有一个setMaxClauseCount函数,用此函数将子查询设置的大些也会减少程序出错的机率,但是付出的就是性能上的降低,如设置为10240时,如果要排序的数据量超过10240个时也将会出现溢出的现象,也以在此建议使用上面说的语法来解决时间段的方式。

   内存索引RAMDirectory,经过测试和资料得到,内存索引搜索的性能提高不大,但是对于建立索引的性能确是非常有帮助,经过测试发现,内存索引在有些时候甚至会比磁盘索引的搜索效率还要慢,但是建立索立大量的索引时确有质的提升,建议建立大量索引时先将索引写入内存索引,当内存索引达到一定量时再将内存索引一次性写入磁盘,但对长时间提供稳定的性能有很大帮助,可以减小硬盘的瓶颈对搜索的影响

   索引的更新,因为lucene不是为频繁进行更新而设计的结构,lucene将所有的精力都放在了如何快速建立索引和进行搜索上,所以数据的更新没有相应的接口,也不可能实再相应的接口,因为它不是像文件一样将数据按条进行存储,它是将数据经过分析后,然后按关键词进行存储,它内部的数据就没有了每条数据的概念,幸好lucene提供了一个删除索引的功能,我们可以利用IndexReader的deleteDocument进行删除索引的操作,它有两个接口可以使用,可以按内部ID号进行删除,也可按词条进行删除,用户可以根据需要进行选择,将要更新的数据先准确删除后再进行添加的操作来完成索引的更新。

   查询类:Query查询有相当多的子类,它分分别实再不同的功能,请查看lucene的官方文档进行研究,其中模糊查询和相似查询相当费时,如果用户想要禁用掉这两个查询可以用如下的代码解决:
   public class XiluQueryParser extends QueryParser
{
 public XiluQueryParser(String f,Analyzer a)
 {
  super(f,a);
 }
 
 /*
  *禁用模糊搜索
  */
 protected Query getFuzzyQuery(String field,
                               String termStr,
                               float minSimilarity)
                        throws ParseException
 {
  throw new ParseException("not allowed");
 }
 
 /*
  *禁止通配符搜索
  */
 protected Query getWildcardQuery(String field,
                                  String termStr)
                           throws ParseException
 {
  throw new ParseException("not allowed");
 }
}
    将QueryParser.parser(title)换为XiluQueryParser.parser(title)即可。

来源:http://club.xilu.com/thinksea/msgview-197162-334.html

分享到:
评论

相关推荐

    基于Lucene的搜索引擎的研究与应用

    这种搜索引擎的开发和应用,不仅提升了搜索引擎的精确性,也为信息检索技术的发展提供了新的思路。 通过上述知识点的分析,可以看出,基于Lucene的搜索引擎具有很高的实用价值和研究意义,尤其是在处理大量非结构化...

    Lucene搜索引擎开发权威经典(附盘源码)【于天恩】.zip

    《Lucene搜索引擎开发权威经典》是由于天恩编著的一本深入探讨Lucene搜索引擎开发的专业书籍,这本书结合源码分析,旨在帮助读者掌握Lucene的核心技术和应用实践。Lucene是Apache软件基金会的一个开放源代码项目,它...

    基于Lucene的搜索引擎

    **基于Lucene的搜索引擎** Lucene是一个开源的全文检索库,由Apache软件基金会开发并维护。它是Java语言实现的,可以被集成到各种应用程序中,为开发者提供了强大的文本搜索功能。在本项目中,我们看到的是一个专门...

    Lucene+nutch搜索引擎开发.part1.rar

    Lucene nutch 搜索引擎开发 Part1

    Lucene.Nutch搜索引擎开发

    学习Lucene和Nutch的入门书籍,学习搜索引擎开发值得一看的书籍

    Lucene+nutch搜索引擎开发 源代码

    《Lucene+nutch搜索引擎开发》书附带的源代码

    开发自己的搜索引擎 lucene + heritrix

    总结来说,开发一个基于Lucene和Heritrix的搜索引擎是一个涉及多种技术和步骤的复杂过程。理解Lucene和Heritrix的工作原理和使用方法,以及如何将两者结合构建有效的搜索引擎,对于完成这项工作至关重要。同时,针对...

    Lucene+nutch搜索引擎开发

    完整的《Lucene+nutch搜索引擎开发》PDF版一共83.6M,无奈我上传的最高限是80M,所以切成两个。这一个是主文件,还需要下载一个副文件Lucene+nutch搜索引擎开发.z01。解压时直接放到一起,解压这个主文件就行了。

    Lucene搜索-引擎开发权威经典pdf+源码第二部分

    《Lucene搜索-引擎开发权威经典》是一本深入解析Apache Lucene搜索引擎库的专业书籍,它为读者提供了构建高效全文搜索引擎的全面指南。Lucene是Java领域最著名的全文检索库,被广泛应用于各种信息检索系统中,包括...

    Heritrix lucene开发自己的搜索引擎(源码)1

    注:随光盘附带的mirror.rar文件是使用Heritrix从pconline网上抓取的手机信息页面(以网站镜象格式存储),在本书最后搜索引擎完整实例中需要使用到。由于光盘容量有限,笔者删除了原始镜像目录中一部分的网页,可能...

    lucene开发WEB搜索引擎

    本文将深入探讨如何使用LUCENE.NET框架来开发一款基于C#的WEB搜索引擎,帮助开发者掌握这一核心技术。 一、LUCENE.NET简介 LUCENE.NET是Apache Lucene的.NET版本,它是一个高性能、全文本搜索库,提供了强大的文本...

    [Lucene搜索引擎开发权威经典].zip

    《Lucene搜索引擎开发权威经典》是一本深入探讨Apache Lucene的专著,作者于天恩在书中详尽地阐述了Lucene的核心概念、工作原理以及实际应用。这本书旨在帮助读者理解如何利用Lucene构建高性能、可扩展的全文搜索...

    Lucene+Nutch搜索引擎开发.王学松源代码

    《Lucene+Nutch搜索引擎开发:王学松源代码解析》 在信息技术日新月异的今天,搜索引擎已经成为了人们获取信息的重要工具。Lucene和Nutch是两个在开源社区广泛使用的搜索引擎技术,它们为开发者提供了构建高效、可...

    Lucene搜索引擎开发权威经典随书资源1-6章

    本书基于Lucene的当前最新版本(2.1)精解了Lucene搜索引擎的相关知识,从基础知识到应用开发,精炼简洁,恰到好处。  本书包含了必要的理论,但以实践为主。所讲的理论都不是纸上谈兵,都是可以立即付诸实践进行...

    基于lucene的搜索引擎regain安装版

    **基于Lucene的搜索引擎Regain安装指南** Regain是一个基于Apache Lucene的全文搜索引擎,它提供了高级的搜索功能,能够帮助用户快速、准确地在大量数据中查找所需信息。Lucene是Java语言实现的一个开源信息检索库...

    lucene 搜索引擎 compass

    而Compass则是一个基于Lucene的搜索引擎框架,它为Lucene提供了更高级别的抽象和更方便的使用方式,让开发更加高效便捷。 Lucene的核心功能包括文档的索引和查询。在示例中,`lucene.html`展示了一个简单的HTML表单...

    Lucene(搜索引擎)开发包

    **Lucene 搜索引擎开发包详解** Lucene 是一个开源的全文检索库,由 Apache 软件基金会维护。它提供了高性能、可扩展的搜索功能,广泛应用于网站、应用程序及大数据分析等领域。作为 Java 语言编写的核心库,Lucene...

    开发自己的搜索引擎《lucene2.0+heritrix》一书对应的源码资料

    在IT领域,搜索引擎开发是一项复杂而关键的任务,它涉及到数据抓取、索引构建、查询处理等多个环节。这里我们关注的是基于开源项目Lucene 2.0...这些知识对于想要深入理解和开发搜索引擎技术的IT专业人士来说是宝贵的。

    Lucene+nutch搜索引擎开发(全本2-2)

    Lucene+nutch搜索引擎开发(全本2-2),本电子书共两部分

Global site tag (gtag.js) - Google Analytics