`
hongwei3344661
  • 浏览: 31902 次
  • 性别: Icon_minigender_1
文章分类
社区版块
存档分类
最新评论

sorl原理

 
阅读更多

solr那是我1年前使用到的一个搜索引擎,由于当初对于配置了相应了,但是今天突然面试问到了,哎,太久了,真的忘记了,今天特地写一篇博客记下来

solr是一个独立的企业级搜索应用服务器,它对外t提供类似于web-service的api接口。用户可以通过http请求,向搜索引擎服务器提交一定格式的xml文件,生成索引。;

也可以通过http get操作提出查询的请求,得到xml/json格式的返回结果

 

Lucene是一个高效的,基于Java的全文检索库。

所以在了解Lucene之前要费一番工夫了解一下全文检索。

那么什么叫做全文检索呢?这要从我们生活中的数据说起。

我们生活中的数据总体分为两种:结构化数据非结构化数据

  • 结构化数据:指具有固定格式或有限长度的数据,如数据库,元数据等。
  • 非结构化数据:指不定长或无固定格式的数据,如邮件,word文档等。

当然有的地方还会提到第三种,半结构化数据,如XML,HTML等,当根据需要可按结构化数据来处理,也可抽取出纯文本按非结构化数据来处理。

非结构化数据又一种叫法叫全文数据。

 

按照数据的分类,搜索也分为两种:

  • 对结构化数据的搜索:如对数据库的搜索,用SQL语句。再如对元数据的搜索,如利用windows搜索对文件名,类型,修改时间进行搜索等。
  • 对非结构化数据的搜索:如利用windows的搜索也可以搜索文件内容,Linux下的grep命令,再如用Google和百度可以搜索大量内容数据。

对非结构化数据也即对全文数据的搜索主要有两种方法:

一种是顺序扫描法(Serial Scanning):所谓顺序扫描,比如要找内容包含某一个字符串的文件,就是一个文档一个文档的看,对于每一个文档,从头看到尾,如果此文档包含此字符串,则此文档为我们要找的文件,接着看下一个文件,直到扫描完所有的文件。如利用windows的搜索也可以搜索文件内容,只是相当的慢。如果你有一个80G硬盘,如果想在上面找到一个内容包含某字符串的文件,不花他几个小时,怕是做不到。Linux下的grep命令也是这一种方式。大家可能觉得这种方法比较原始,但对于小数据量的文件,这种方法还是最直接,最方便的。但是对于大量的文件,这种方法就很慢了。

有人可能会说,对非结构化数据顺序扫描很慢,对结构化数据的搜索却相对较快(由于结构化数据有一定的结构可以采取一定的搜索算法加快速度),那么把我们的非结构化数据想办法弄得有一定结构不就行了吗?

这种想法很天然,却构成了全文检索的基本思路,也即将非结构化数据中的一部分信息提取出来,重新组织,使其变得有一定结构,然后对此有一定结构的数据进行搜索,从而达到搜索相对较快的目的。

这部分从非结构化数据中提取出的然后重新组织的信息,我们称之索引

这种说法比较抽象,举几个例子就很容易明白,比如字典,字典的拼音表和部首检字表就相当于字典的索引,对每一个字的解释是非结构化的,如果字典没有音节表和部首检字表,在茫茫辞海中找一个字只能顺序扫描。然而字的某些信息可以提取出来进行结构化处理,比如读音,就比较结构化,分声母和韵母,分别只有几种可以一一列举,于是将读音拿出来按一定的顺序排列,每一项读音都指向此字的详细解释的页数。我们搜索时按结构化的拼音搜到读音,然后按其指向的页数,便可找到我们的非结构化数据——也即对字的解释。

   这种先建立索引,在对索引进行搜索的过程就叫做全文检索。

  全文检索大体分为2个过程,索引创建和搜索索引

 1.索引创建:将现实世界中的所有结构化和非结构化数据提取信息,创建索引的过程

 2.索引索引:就是得到用户查询的请求,搜索创建的索引,然后返回结果的过程

 于是全文检索就存在3个重要的问题:

 1. 索引里面究竟存了什么东西?

 2.如何创建索引?

 3.如何对索引进行搜索?

 

下面我们顺序对每个个问题进行研究。

 

二、索引里面究竟存些什么

索引里面究竟需要存些什么呢?

首先我们来看为什么顺序扫描的速度慢:

其实是由于我们想要搜索的信息和非结构化数据中所存储的信息不一致造成的。

非结构化数据中所存储的信息是每个文件包含哪些字符串,也即已知文件,欲求字符串相对容易,也即是从文件到字符串的映射。而我们想搜索的信息是哪些文件包含此字符串,也即已知字符串,欲求文件,也即从字符串到文件的映射。两者恰恰相反。于是如果索引总能够保存从字符串到文件的映射,则会大大提高搜索速度。

由于从字符串到文件的映射是文件到字符串映射的反向过程,于是保存这种信息的索引称为反向索引

反向索引的所保存的信息一般如下:

假设我的文档集合里面有100篇文档,为了方便表示,我们为文档编号从1到100,得到下面的结构

 

string1-----------》对象-------对象---------对象
string2-----------》对象-------对象
string3-----------》对象-------对象---------对象----------对象-

左边保存的是一系列字符串,称为词典

每个字符串都指向包含此字符串的文档(Document)链表,此文档链表称为倒排表(Posting List)。

有了索引,便使保存的信息和要搜索的信息一致,可以大大加快搜索的速度。

比如说,我们要寻找既包含字符串“lucene”又包含字符串“solr”的文档,我们只需要以下几步:

1. 取出包含字符串“lucene”的文档链表。

2. 取出包含字符串“solr”的文档链表。

3. 通过合并链表,找出既包含“lucene”又包含“solr”的文件。

 

看到这个地方,有人可能会说,全文检索的确加快了搜索的速度,但是多了索引的过程,两者加起来不一定比顺序扫描快多少。的确,加上索引的过程,全文检索不一定比顺序扫描快,尤其是在数据量小的时候更是如此。而对一个很大量的数据创建索引也是一个很慢的过程。

然而两者还是有区别的,顺序扫描是每次都要扫描,而创建索引的过程仅仅需要一次,以后便是一劳永逸的了,每次搜索,创建索引的过程不必经过,仅仅搜索创建好的索引就可以了。

这也是全文搜索相对于顺序扫描的优势之一:一次索引,多次使用。

 

三、如何创建索引

全文检索的索引创建过程一般有以下几步:

第一步:一些要索引的原文档(Document)。

为了方便说明索引创建过程,这里特意用两个文件为例:

文件一:Students should be allowed to go out with their friends, but not allowed to drink beer.

文件二:My friend Jerry went to school to see his students but found them drunk which is not allowed.

 

第二步:将原文档传给分次组件(Tokenizer)。

分词组件(Tokenizer)会做以下几件事情(此过程称为Tokenize):

1. 将文档分成一个一个单独的单词。

2. 去除标点符号。

3. 去除停词(Stop word)。

所谓停词(Stop word)就是一种语言中最普通的一些单词,由于没有特别的意义,因而大多数情况下不能成为搜索的关键词,因而创建索引时,这种词会被去掉而减少索引的大小。

英语中挺词(Stop word)如:“the”,“a”,“this”等。

对于每一种语言的分词组件(Tokenizer),都有一个停词(stop word)集合。

经过分词(Tokenizer)后得到的结果称为词元(Token)。

在我们的例子中,便得到以下词元(Token):

“Students”,“allowed”,“go”,“their”,“friends”,“allowed”,“drink”,“beer”,“My”,“friend”,“Jerry”,“went”,“school”,“see”,“his”,“students”,“found”,“them”,“drunk”,“allowed”。

第三步:将得到的词元(Token)传给语言处理组件(Linguistic Processor)。

语言处理组件(linguistic processor)主要是对得到的词元(Token)做一些同语言相关的处理。

对于英语,语言处理组件(Linguistic Processor)一般做以下几点:

1. 变为小写(Lowercase)。

2. 将单词缩减为词根形式,如“cars”到“car”等。这种操作称为:stemming。

3. 将单词转变为词根形式,如“drove”到“drive”等。这种操作称为:lemmatization

第四步:将得到的词(Term)传给索引组件(Indexer)。等等

总而言之

 

1. 索引过程:

1) 有一系列被索引文件

2) 被索引文件经过语法分析和语言处理形成一系列词(Term)。

3) 经过索引创建形成词典和反向索引表。

4) 通过索引存储将索引写入硬盘。

2. 搜索过程:

a) 用户输入查询语句。

b) 对查询语句经过语法分析和语言分析得到一系列词(Term)。

c) 通过语法分析得到一个查询树。

d) 通过索引存储将索引读入到内存。

e) 利用查询树搜索索引,从而得到每个词(Term)的文档链表,对文档链表进行交,差,并得到结果文档。

f) 将搜索到的结果文档对查询的相关性进行排序。

g) 返回查询结果给用户。

分享到:
评论

相关推荐

    sorl安装文档-sorl安装文档

    ### Sorl安装与配置详解 #### 一、Sorl简介 Sorl是一个常见的拼写错误,正确的术语应该是Solr。Apache Solr是一款高性能、采用Java开发的全文搜索引擎,通常用于网站搜索、企业级搜索以及其他需要高效处理大量数据...

    sorl 安装包

    sorl是一个广泛使用的全文搜索引擎库,它为Python应用程序提供了强大的搜索功能。在本文中,我们将深入探讨sorl的核心概念、安装过程以及如何利用它来构建高效、可扩展的搜索解决方案。 首先,让我们理解sorl的核心...

    sorl详细搭建配置

    文档内有详细的sorl搭建的步骤

    sorl的安装与配置详解.pdf

    在技术文档《sorl的安装与配置详解.pdf》中,详细介绍了如何在CentOS 7操作系统上安装和配置Solr,以及如何进行基本的中文分析器配置。接下来,我们将根据文件内容详细说明安装和配置Solr的关键知识点。 首先,安装...

    sorl单点环境搭建

    Solr是Apache软件基金会开发的一款高性能、全文搜索引擎,常用于构建大规模的搜索应用。在本文中,我们将深入探讨如何在单点环境中搭建Solr,包括必要的安装步骤、配置过程以及如何启动和使用Solr。...

    sorl学习笔记及相关教程

    《SOLR学习笔记及相关教程综合解析》 SOLR,全称为Apache Solr,是Apache软件基金会的一个开源项目,是基于Java的全文检索服务器。它提供了高效、可扩展的搜索和导航功能,广泛应用于各类企业的信息检索系统。...

    sorl1下载4.10.3安装详情都有.zip

    **Solr 4.10.3 下载与安装指南** Apache Solr 是一个流行的开源搜索引擎,用于处理和索引大量数据,以便进行快速、高效的全文检索。在本指南中,我们将详细介绍如何下载和安装 Solr 4.10.3 版本,并配置其所需的...

    Python库 | sorl-thumbnail-12.1c.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:sorl-thumbnail-12.1c.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    搜索引擎 工作原理

    ### 搜索引擎的工作原理与发展现状 #### 摘要与背景 搜索引擎作为互联网时代不可或缺的工具之一,在信息获取过程中扮演着重要角色。本文旨在介绍搜索引擎的基本概念,深入探讨其工作原理及类型,并分析当前搜索...

    Sorl8 所需要 ik-analyzer jar包以及配置文件和中文字典

    Sorl8版本 所需要 ik-analyzer jar包以及配置文件和中文字典 , 包括如下文件 ik-analyzer最新包:ik-analyzer-7.7.1.jar ik-analyzer配置文件:IKAnalyzer.cfg.xml 扩展字典:hotword.dic 扩展停止词字典:...

    Spring Boot集成Sorl搜索客户端的实现代码

    在本文中,我们将深入探讨如何在Spring Boot应用中集成Sorl(Apache Solr)作为搜索客户端。Apache Solr是一个开源的全文搜索引擎,它能够快速处理大量数据,并提供高效的搜索功能。Spring Boot通过其`spring-boot-...

    sorl-thumbnail-12.9.0.tar.gz.tar

    sorl-thumbnail-12.9.0.tar.gz.tar

    sorl企业级检索服务部署-快速检索

    在企业级应用中,高效的检索服务是至关重要的,它能够帮助用户快速找到所需的信息,提升用户体验,增强业务效率。SOLR(Search Server)是由Apache软件基金会开发的一个开源搜索引擎,它提供了一个分布式、可扩展、...

    sorl-thumbnail-serializer-field:与sorl和Django REST Framework一起使用的图像序列化器字段

    唯一缩略图序列化器字段 与sorl和Django REST Framework一起使用的图像序列化器字段。 提供一种简单的方式来显示图像的缩放版本而不是全尺寸图像,并且如果您喜欢几种不同的版本(缩略图,大尺寸等),安装聚酰亚胺...

    sorl-watermark:基于图像的水印缩略图

    单一水印sorl-水印为sorl-thumbnail添加了对水印的支持。 支持: Django 1.3+(已在Django 1.10.4到2.1上进行了测试) Soul-Thumbnail 11+(经12.4a1至12.5.0测试) 枕头3+(经过3、4.2和5的测试) Python 2.7至3.7 ...

    sorl in action (最新版)

    《Solr in Action》是一本关于Solr的实践指南,最新版本介绍了solr4.2.1底层所使用的最新***4.2.1技术。Solr是一个开源的搜索平台,基于Apache Lucene构建,它能够提供强大的搜索引擎功能,尤其适用于Web应用程序。...

    sorl-thumbnail:Django的缩略图

    Django的缩图。 功能一览 遵循支持Django 2.2、3.0和3.1 Python 3支持 ... 如果您需要开发支持或想与其他开发人员讨论,请通过freenode.net或Gitter上的#sorl-thumnbnail频道加入我们。 有关发行版更

    跟益达学Solr5之批量索引JSON数据

    在Solr5中批量索引JSON数据是一项重要的操作,理解其工作原理和优化技巧能大幅提升数据处理效率。通过合理的设计和配置,Solr可以帮助我们构建一个强大、高效的全文搜索引擎,为业务发展提供有力支撑。

    solr自动导入数据jar

    实现从数据库到solr的全量数据导入及增量数据导入jar包

    django-oscar-easy-thumbnail:这个包将把所有为 sorl-thumbnails 添加的模板标签替换为 easy-thumbnails

    "django-oscar-easy-thumbnail" 是一个针对 Django Oscar 框架的扩展,它旨在替换原本的 "sorl-thumbnails" 库,转而使用 "easy-thumbnails" 来处理图像缩略图的生成。Django Oscar 是一个高度可定制的电子商务平台...

Global site tag (gtag.js) - Google Analytics