转载请声明出处,谢谢。翻译也很辛苦
本章涵盖了
• Solr有别于传统的数据库技术是什么
•Solr内部索引的基本结构
•Solr如何执行复杂查询使用术语、短语,和模糊匹配
•Solr如何计算分数匹配查询最相关的文档
•如何平衡返回相关结果和返回所有可能的结果
•如何模型内容到规范化的文档
•Solr跨服务器如何处理数十亿的文档和查询
现在我们已经Solr启动并运行,获得一个基本的了解是很重要的,搜索引擎如何运作,以及为什么你会选择使用Solr存储和检索你的内容。这一章我们的主要目标是提供理论基础,所以你能理解并最大化使用Solr。
如果你在搜索和信息检索有一个坚实的背景,那么您可能希望跳过这一章的部分或全部,但如果没有,它将帮助你了解更先进主题在这本书和最大化的质量用户的搜索体验
虽然在本章的内容通常是适用于大多数搜索引擎,我们会是特别关注Solr的每个概念的实现。这一章结尾,你应该有一个坚实的理解Solr的内部索引是如何工作的, Solr如何执行复杂的布尔和模糊查询,Solr的违约相关性如何评分模型作品,Solr的架构使查询保持最快的速度处理数十亿的文件在许多服务器。
让我们开始讨论背后的核心概念在Solr搜索,包括如何搜索索引,搜索引擎如何匹配查询和文档,以及如何Solr使强大的查询功能,以便使寻找内容的问题。
3.1。搜索、匹配和发现内容
许多不同种类的系统来帮助我们解决具有挑战性的数据存储和存在检索问题:关系数据库、键值存储- reduce引擎操作在磁盘上的文件,图形数据库,在许多其他人。搜索引擎,Solr特别有助于解决一个特定类的问题相当well-problems要求能搜索大量的非结构化文本和拉回相关的结果。
在本节中,我们将描述现代搜索引擎的核心功能,包括一个解释一个搜索“文档”,概述反向搜索索引的核心Solr的快速全文搜索功能,和一个广泛的概述如何倒排搜索索引允许任意复杂的词、短语和partial-matching查询。
3.1.1。一个文档是什么?
我们发布了一些文档Solr在第二章,然后运行示例搜索Solr,所以这不是我们第一次提到的文件。然而,它是我们充分理解的信息我们可以投入Solr搜索(文档)和如何结构化信息重要的。
Solr文档存储和检索引擎。每一个数据报Solr处理一个文档。一个文档可能是报纸的一篇文章中,简历或社会配置文件,或者在极端情况下,整本书。
每个文档包含一个或多个字段,每个被建模为一个特定的领域类型:字符串,标记化的文本、布尔值、日期/时间,纬度/经度等潜在的数量字段类型是无限的,因为一个字段类型是由零个或多个步骤,分析改变字段中的数据处理和映射到Solr索引。每个字段Solr中定义的模式(在第五章讨论)作为一个特定的字段类型,它允许Solr知道如何处理接收到的内容的。清单3.1显示了一个示例文档,为每个字段定义的值。
清单3.1。Solr示例文档
<doc> <field name="id">company123</field> <field name="companycity">Atlanta</field> <field name="companystate">Georgia</field> <field name="companyname">Code Monkeys R Us, LLC</field> <field name="companydescription">we write lots of code</field> <field name="lastmodified">2013-06-01T15:26:37Z</field> </doc>
当我们运行一个查询Solr,我们可以搜索一个或多个字段(甚至字段不包含在这个特定的文档),Solr将返回在这些字段包含内容匹配查询的文档。
值得注意的是,虽然Solr灵活的模式为每个文档,它不是“非模式化。“所有必须定义字段类型,字段名称(或动态field-naming模式)应该在Solr中指定schema.xml,我们将进一步讨论在第5章。这并不意味着每个文档必须包含各个领域,只有这一点所有可能的领域必须可映射到一个特定的字段类型应该出现在文档,需要处理。Solr包含自动猜测的能力以前看不见的字段名称的字段类型当它第一次收到的文档新字段名。这是通过检查字段和数据类型自动添加字段Solr的模式。因为Solr可能猜出错误的字段类型如果输入是混乱的,这是一个更好的实践来预先确定。
一个文档,是一集合字段映射到特定的字段类型中定义模式。文档中每个字段的内容分析根据其字段类型,和这种分析的结果保存到后来搜索索引来检索文档通过发送一个相关的查询。主要从Solr搜索结果返回查询文件包含一个或多个字段。
3.1.2。基本的搜索问题
在我们深入概述Solr搜索是如何工作的理解很有帮助搜索引擎要解决的基本问题。
比方说你是负责创建搜索功能,帮助用户搜索书。初始原型看起来如图3.1所示。
图3.1。示例搜索界面,会看到在一个典型的网站上,展示用户如何提交一个查询到您的应用程序
现在假设一个客户想找一本关于采购一个新家搜索买房。一些潜在相关书名你可能想要返回表3.1列出了。
表3.1。相关书籍查询“买房”
潜在的相关书籍
买房子的初学者的指南
如何购买你的第一个房子吗
潜在的相关书籍
买房
成为一个新的业主
买新房子
装饰你的家
其他书名,如表3.2所示,将不会被认为是相关的客户购买新房子感兴趣。
表3.2。书与查询无关的“买房”
无关紧要的书
一个有趣的烹饪指南
如何提高孩子的事情吗
买一辆新车
一个天真的方法来实现这种搜索使用传统的SQL数据库查询的用户输入的文本:
SELECT * FROM Books WHERE Name = 'buying a new home';
这种方法的问题是,在你的书的书名目录匹配文本,客户类型,这意味着他们将不会找到任何结果
对于这个查询。此外,客户只会看到未来的查询,如果查询的结果匹配准确完整的书名。
也许一个更宽容的方法是在一个客户的查询寻找每一个词:
SELECT * FROM Books
WHERE Name LIKE '%buying%'
AND Name LIKE '%a%'
AND Name LIKE '%home%';
前面的查询,虽然相对昂贵的传统数据库来处理因为它不能使用可用的数据库索引,至少会产生一个匹配客户包含所有所需的单词,如表3.3所示。
表3.3。结果从数据库查询要求的模糊匹配每个term
匹配的书 |
没有匹配的书 |
买新房子 |
买房子的初学者的指南 |
|
如何购买你的第一个房子吗 |
|
买房 |
|
成为一个新的业主 |
|
一个有趣的烹饪指南 |
|
如何提高孩子的事情吗 |
|
买一辆新车 |
|
装饰你的家 |
当然,你可能会认为, 客户包括在他们的查询要求文档匹配你所有的单词过于严格的。您可以轻松地搜索体验更灵活的只需要一个词存在于任何匹配的书标题,通过发出以下SQL查询:
SELECT * FROM Books
WHERE Name LIKE '%buying%'
OR Name LIKE '%a%'
OR Name LIKE '%home%';
这个查询的结果中可以看到在表3.4。你会发现这个查询匹配很多比之前的查询书名因为该查询只需要最少的其中一个关键字匹配。此外,由于这个查询的方法是执行部分字符串匹配的每个关键字,任何书名包含字母“a”也返回。前面的示例,它要求所有的条款,也匹配字母“a”,但我们没有经历这个问题返回的结果,因为太多了另一个关键字更严格。
表3.4。结果从数据库查询只需要一个模糊匹配的至少一个term
匹配的书 |
没有匹配的书 |
一个有趣的烹饪指南 |
如何购买你的第一个房子吗 |
装饰你的家 |
|
如何提高孩子的事情吗 |
|
买一辆新车 |
|
买新房子 |
|
买房子的初学者的指南 |
|
买房 |
|
成为一个新的业主 |
|
第一个查询(要求所有单词匹配)导致了许多不相关的书籍发现;第二个查询(只需要其中一个单词匹配)导致了许多更相关的书被发现但导致许多无关紧要的书被发现好。
这些例子展示几个与这个实现的困难:
•它只执行子字符串匹配和无法区分单词。
•它不懂语言的变化,如“买”与“买”。
•它不理解同义词的单词,如“购买”和“采购”或家”和“房子。”
•不重要的词如“a”(防止结果匹配预期排除等相关结果或不相关的结果,这取决于是否“所有”或“任何”的单词必须匹配)。
•没有意义的相关性排序结果;只有一个匹配的书籍查询词经常出现高于匹配多个或全部的书在客户的查询。
随着图书目录的大小或数量客户查询的增长这些查询将变得缓慢,因为查询必须通过每一本书的标题找到扫描部分匹配,而不是使用索引来查找单词。
搜索引擎Solr照耀在解决此类问题。Solr是能够执行文本分析内容和搜索查询来确定文本相似的单词,理解和匹配同义词,删除不重要“,”这样的词“的”和“,”,得分每个结果基于传入的查询,以确保它匹配
最好的结果返回第一个,你的客户不需要页面无数less-relevant结果找到他们期望的内容。Solr完成所有这些通过使用地图内容的索引文件,而不是映射文件内容在传统的数据库模型。这种反向索引是搜索引擎如何工作的核心。
3.1.3。反向索引
Solr使用Lucene的反向索引其快速搜索功能,以及许多额外的,它提供的查询。虽然我们不会进入许多内部Lucene数据结构在这本书中,重要的是要了解的高层结构的反向索引。(我们建议Lucene in action,第二版,由迈克尔•麦卡Erik孵卵,奥蒂斯Gospodnetić[曼宁,2010]你可以看看)。
回忆我们以前book-searching的例子中,我们可以领略到一个索引每个术语映射到每个文档看起来就像从表3.5。
表3.5。将多个文档的文本映射到一个反向索引。正确的表包含一个反向搜索索引显示的每一个条款,
连同它的位置,在从左表原始文档。
原始文档 |
Lucene的反响索引 |
|||
Doc |
内容 |
Term |
Doc |
Continued |
4 5 6 |
Cooking |
|
|
|
7 8 9 |
Decorating Your Home How to Raise a Child Buying a New Car Buying a New Home The Beginner’s Guide to Buying a House Purchasing a Home Becoming a New Home Owner How to Buy Your First House |
beginner’s buy buying car child cooking decorating first fun ... |
8 6 9 4,5,6 4 3 1 2 9 1 ... |
home house 2,5,7,8 how new 6,9 3,9 owner 4,5,8 8 purchasing 7 3 6 raise the to 1,6,9 your 2,9 |
而传统数据库的多个文档将包含一个表示文档的ID映射到一个或多个内容字段包含的所有单词/条款
文档,一个反向索引反转这个模型和地图每一个字/词语料库中,似乎所有的文档。你可以告诉从表3.5
,原始输入文本分割空间,每个术语转换成小写字母文本前插入到反向索引,但一切仍相同的。值得注意的是,许多额外的文本转换是可能的,不是只是这些简单的;术语可以被修改,补充说,期间或删除本文的过程,这将在第六章中详细介绍。
反向索引两个最终重要的细节应该注意的:
•所有term在索引映射到一个或多个文件。
•在反向索引是辞典编纂的升序排列。
这一观点的反向索引是大大简化;3.1.6节中我们将看到这一点附加信息可以存储在索引来提高Solr的查询和得分能力。
在下一节中您将看到,Lucene的反向索引的结构允许许多强大的查询功能, 关键字搜索最大化的速度和灵活性。
相关推荐
在理解这个知识点之前,我们需要先了解Solr的基本概念以及数据导入处理(DataImportHandler,DIH)。 Apache Solr是一个开源的全文搜索引擎,它提供了高效、可扩展的搜索和分析功能。Solr能够对大量数据进行快速的...
solr-mongo-importer-1.1.0.jar solr-mongo-importer-1.1.0.jar solr-mongo-importer-1.1.0.jar
标题中的“Solr in Action -- Apache Solr 在比价系统中的应用”表明本文将深入讨论Apache Solr搜索服务器在比价系统中的实际应用案例。Apache Solr是一个开源的搜索引擎平台,广泛应用于企业级应用中,以提高搜索...
Solr 是一个流行的开源全文搜索引擎,它提供了高效、可扩展的搜索和索引能力。在 Solr 的生态系统中,`solr-dataimport-scheduler-1.2.jar` 是一个非常重要的组件,它允许用户定时执行数据导入任务,这对于需要定期...
- `contrib`: 第三方贡献的模块,如数据导入工具等。 - `dist`: 发布的可执行文件和jar包。 - `docs`: 文档和API参考。 - `example`: 示例配置和启动脚本,帮助快速启动和测试Solr实例。 - `lucene`: 内含...
solr-import-export-json最新代码solr-import-export-json最新代码solr-import-export-json最新代码solr-import-export-json最新代码solr-import-export-json最新代码solr-import-export-json最新代码solr-import-...
《Solr In Action》中文版第八章主要探讨的是Solr中的分类搜索,也称为分类导航或分类浏览。分类是Solr的一个强大特性,它允许用户根据一个或多个分类过滤搜索结果,提供更丰富的探索和分析体验。本章涵盖的内容包括...
经过测试可以适用solr7.4版本。如果低版本solr(6.*) 可以直接适用网上的solr-dataimport-scheduler 1.1 或者1.0版本。
Solr 数据导入调度器(solr-dataimport-scheduler)是一个实用工具,用于自动化Apache Solr中的数据导入过程,尤其适用于需要定期从关系型数据库同步数据的场景。Solr 是一个流行的开源全文搜索引擎,它提供了强大的...
Solr是Apache Lucene项目下的一个企业级搜索服务器,它提供了全文检索、命中高亮、 faceted search(分面搜索)等多种功能。在Solr6版本中,DataImportHandler(DIH)是一个非常重要的特性,它允许Solr从外部数据源...
3. **dist 目录**:包含Solr的JAR文件和其他库,这些是运行Solr服务所必需的。 4. **example 目录**:提供了一个预配置的Solr实例,用于快速入门和测试。它包括一个默认的配置集,以及一个简单的数据导入处理程序...
solr 增量更新所需要的包 solr-dataimporthandler-6.5.1 + solr-dataimporthandler-extras-6.5.1 + solr-data-import-scheduler-1.1.2
增量更新是Solr的一个关键特性,它允许系统仅处理自上次完整索引以来发生更改的数据,从而提高了性能并降低了资源消耗。"apache-solr-dataimportscheduler.jar" 是一个专门为Solr设计的扩展包,用于实现自动化的数据...
3. **配置DataImportHandler**:在对应的Solr核心的`schema.xml`或`managed-schema`文件中,配置DataImportHandler,包括数据源、查询语句、字段映射等信息。 4. **启动定时任务**:一旦配置完成,重启Solr服务器,...
3. **实时索引**:Solr能够实时地处理新数据的索引和搜索,提高了系统的响应速度。 4. **多字段搜索**:支持对多个字段进行独立或组合的查询,同时可以设置不同字段的权重。 5. ** faceted search(分面搜索)**:...
这是我自己反编译fix后,支持solr7.4高版本的定时增量任务(亲测solr7.4),下载下来开箱即用。低版本的没试过,估计低版本的solr配合之前apache-solr-dataimportscheduler-1.0.jar这些能行,不行就试试我这个。
Solr in Action is the definitive guide to implementing fast and scalable search using Apache Solr 4. It uses well-documented examples ranging from basic keyword searching to scaling a system for ...
solr-data-import-scheduler-1.1.2,用于solr定时更新索引的jar包,下载后引入到solr本身的dist下面,或者你tomcat项目下面的lib下面
在给定的压缩包“apache-solr-dataimporthandler-extras-1.4.0.jar.zip”中,主要包含了一个名为“apache-solr-dataimporthandler-extras-1.4.0.jar”的文件,这个文件是Solr的一个重要组件——DataImportHandler...
### Solr In Action 中文版 第六章:深入探索文本分析 #### 一、文本分析的重要性及作用 在本章中,《Solr In Action》深入探讨了文本分析的关键概念及其在Solr中的应用。文本分析是指对文本数据进行处理的过程,...