`
m635674608
  • 浏览: 5028944 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Elasticsearch与Solr 选型

 
阅读更多

搜索引擎选择: Elasticsearch与Solr

搜索引擎选型调研文档

Elasticsearch简介*

Elasticsearch是一个实时分布式搜索和分析引擎。它可以帮助你用前所未有的速度去处理大规模数据。

它可以用于全文搜索结构化搜索以及分析,当然你也可以将这三者进行组合。

Elasticsearch是一个建立在全文搜索引擎 Apache Lucene™ 基础上的搜索引擎,可以说Lucene是当今最先进,最高效的全功能开源搜索引擎框架。

但是Lucene只是一个框架,要充分利用它的功能,需要使用JAVA,并且在程序中集成Lucene。需要很多的学习了解,才能明白它是如何运行的,Lucene确实非常复杂。

Elasticsearch使用Lucene作为内部引擎,但是在使用它做全文搜索时,只需要使用统一开发好的API即可,而不需要了解其背后复杂的Lucene的运行原理。

当然Elasticsearch并不仅仅是Lucene这么简单,它不但包括了全文搜索功能,还可以进行以下工作:

  • 分布式实时文件存储,并将每一个字段都编入索引,使其可以被搜索。

  • 实时分析的分布式搜索引擎。

  • 可以扩展到上百台服务器,处理PB级别的结构化或非结构化数据。

这么多的功能被集成到一台服务器上,你可以轻松地通过客户端或者任何你喜欢的程序语言与ES的RESTful API进行交流。

Elasticsearch的上手是非常简单的。它附带了很多非常合理的默认值,这让初学者很好地避免一上手就要面对复杂的理论,

它安装好了就可以使用了,用很小的学习成本就可以变得很有生产力。

随着越学越深入,还可以利用Elasticsearch更多高级的功能,整个引擎可以很灵活地进行配置。可以根据自身需求来定制属于自己的Elasticsearch。

使用案例:

  • 维基百科使用Elasticsearch来进行全文搜做并高亮显示关键词,以及提供search-as-you-type、did-you-mean等搜索建议功能。

  • 英国卫报使用Elasticsearch来处理访客日志,以便能将公众对不同文章的反应实时地反馈给各位编辑。

  • StackOverflow将全文搜索与地理位置和相关信息进行结合,以提供more-like-this相关问题的展现。

  • GitHub使用Elasticsearch来检索超过1300亿行代码。

  • 每天,Goldman Sachs使用它来处理5TB数据的索引,还有很多投行使用它来分析股票市场的变动。

但是Elasticsearch并不只是面向大型企业的,它还帮助了很多类似DataDog以及Klout的创业公司进行了功能的扩展。

Elasticsearch的优缺点**:

优点

  1. Elasticsearch是分布式的。不需要其他组件,分发是实时的,被叫做”Push replication”。
  2. Elasticsearch 完全支持 Apache Lucene 的接近实时的搜索。
  3. 处理多租户multitenancy)不需要特殊配置,而Solr则需要更多的高级设置。
  4. Elasticsearch 采用 Gateway 的概念,使得完备份更加简单。
  5. 各节点组成对等的网络结构,某些节点出现故障时会自动分配其他节点代替其进行工作。

缺点

  1. 只有一名开发者(当前Elasticsearch GitHub组织已经不只如此,已经有了相当活跃的维护者)
  2. 还不够自动(不适合当前新的Index Warmup API)

Solr简介*

Solr(读作“solar”)是Apache Lucene项目的开源企业搜索平台。其主要功能包括全文检索命中标示分面搜索动态聚类数据库集成,以及富文本(如Word、PDF)的处理。Solr是高度可扩展的,并提供了分布式搜索和索引复制。Solr是最流行的企业级搜索引擎,Solr4 还增加了NoSQL支持。

Solr是用Java编写、运行在Servlet容器(如 Apache Tomcat 或Jetty)的一个独立的全文搜索服务器。 Solr采用了 Lucene Java 搜索库为核心的全文索引和搜索,并具有类似REST的HTTP/XML和JSON的API。Solr强大的外部配置功能使得无需进行Java编码,便可对其进行调整以适应多种类型的应用程序。Solr有一个插件架构,以支持更多的高级定制。

因为2010年 Apache Lucene 和 Apache Solr 项目合并,两个项目是由同一个Apache软件基金会开发团队制作实现的。提到技术或产品时,Lucene/Solr或Solr/Lucene是一样的。

Solr的优缺点

优点

  1. Solr有一个更大、更成熟的用户、开发和贡献者社区。
  2. 支持添加多种格式的索引,如:HTML、PDF、微软 Office 系列软件格式以及 JSON、XML、CSV 等纯文本格式。
  3. Solr比较成熟、稳定。
  4. 不考虑建索引的同时进行搜索,速度更快。

缺点

  1. 建立索引时,搜索效率下降,实时索引搜索效率不高。

Elasticsearch与Solr的比较*

当单纯的对已有数据进行搜索时,Solr更快。

Search Fesh Index While Idle

当实时建立索引时, Solr会产生io阻塞,查询性能较差, Elasticsearch具有明显的优势。

search_fresh_index_while_indexing

随着数据量的增加,Solr的搜索效率会变得更低,而Elasticsearch却没有明显的变化。

search_fresh_index_while_indexing

综上所述,Solr的架构不适合实时搜索的应用。

实际生产环境测试*

下图为将搜索引擎从Solr转到Elasticsearch以后的平均查询速度有了50倍的提升。

average_execution_time

Elasticsearch 与 Solr 的比较总结

  • 二者安装都很简单;
  • Solr 利用 Zookeeper 进行分布式管理,而 Elasticsearch 自身带有分布式协调管理功能;
  • Solr 支持更多格式的数据,而 Elasticsearch 仅支持json文件格式;
  • Solr 官方提供的功能更多,而 Elasticsearch 本身更注重于核心功能,高级功能多有第三方插件提供;
  • Solr 在传统的搜索应用中表现好于 Elasticsearch,但在处理实时搜索应用时效率明显低于 Elasticsearch。

Solr 是传统搜索应用的有力解决方案,但 Elasticsearch 更适用于新兴的实时搜索应用。

其他基于Lucene的开源搜索引擎解决方案*

  1. 直接使用 Lucene

说明:Lucene 是一个 JAVA 搜索类库,它本身并不是一个完整的解决方案,需要额外的开发工作。

优点:成熟的解决方案,有很多的成功案例。apache 顶级项目,正在持续快速的进步。庞大而活跃的开发社区,大量的开发人员。它只是一个类库,有足够的定制和优化空间:经过简单定制,就可以满足绝大部分常见的需求;经过优化,可以支持 10亿+ 量级的搜索。

缺点:需要额外的开发工作。所有的扩展,分布式,可靠性等都需要自己实现;非实时,从建索引到可以搜索中间有一个时间延迟,而当前的“近实时”(Lucene Near Real Time search)搜索方案的可扩展性有待进一步完善

说明:基于 Lucene 的,支持分布式,可扩展,具有容错功能,准实时的搜索方案。

优点:开箱即用,可以与 Hadoop 配合实现分布式。具备扩展和容错机制。

缺点:只是搜索方案,建索引部分还是需要自己实现。在搜索功能上,只实现了最基本的需求。成功案例较少,项目的成熟度稍微差一些。因为需要支持分布式,对于一些复杂的查询需求,定制的难度会比较大。

说明:Map/Reduce 模式的,分布式建索引方案,可以跟 Katta 配合使用。

优点:分布式建索引,具备可扩展性。

缺点:只是建索引方案,不包括搜索实现。工作在批处理模式,对实时搜索的支持不佳。

说明:基于 Lucene 的一系列解决方案,包括 准实时搜索 zoie ,facet 搜索实现 bobo ,机器学习算法 decomposer ,摘要存储库 krati ,数据库模式包装 sensei 等等

优点:经过验证的解决方案,支持分布式,可扩展,丰富的功能实现

缺点:与 linkedin 公司的联系太紧密,可定制性比较差

说明:基于 Lucene,索引存在 cassandra 数据库中

优点:参考 cassandra 的优点

缺点:参考 cassandra 的缺点。另外,这只是一个 demo,没有经过大量验证

说明:基于 Lucene,索引存在 HBase 数据库中

优点:参考 HBase 的优点

缺点:参考 HBase 的缺点。另外,在实现中,lucene terms 是存成行,但每个 term 对应的 posting lists 是以列的方式存储的。随着单个 term 的 posting lists 的增大,查询时的速度受到的影响会非常大

 

http://m.blog.csdn.net/blog/fz2543122681/44905643

分享到:
评论

相关推荐

    es与solr的区别_solr_ES_es与solr的区别_elasticsearch_

    在大数据和搜索引擎领域,Elasticsearch (ES) 和 Apache Solr 都是广泛使用的开源技术,它们都基于 Lucene 库,提供高性能、可扩展的全文搜索和分析能力。然而,两者在设计哲学、使用场景、功能特性以及社区支持等...

    ES和solr搜索方案对比

    ES(ElasticSearch)和Solr都是基于Lucene的搜索引擎,它们各自提供了一套搜索框架,用于实现高效的全文搜索功能。由于两者都是在Apache License 2下开源的,因此在选择使用哪种搜索方案时,需要根据不同的使用场景...

    Solr 与 Elasticsearch 的对比与选型

    一、Elasticsearch特性 1.1 安装管理方便 Elasticsearch没有其他依赖,下载后安装非常方便;只用修改几个参数就可以搭建起来一个集群。 1.2 大规模分布式 Elasticsearch允许你开始小规模使用,但是随着你使用数据的...

    分布式搜索方案选型

    在分布式搜索系统中,常见的技术包括Elasticsearch、Solr、Apache Lucene等。Elasticsearch是一款基于Lucene的开源全文搜索引擎,以其易于使用、实时性高和分布式特性而受到广泛应用。Solr则是另一个强大的搜索平台...

    五大分布式搜索方案选型.doc

    Solandra是Solr与NoSQL数据库Cassandra的结合,利用Cassandra的分布式特性和容错机制。Solandra的索引存储在Cassandra中,简化了部署过程,但其首次查询效率较低,因为索引需从数据库读取,而非直接从文件系统。此外...

    Hadoop技术选型分析报告V4.0.pdf

    - Elasticsearch和Solr等分布式检索引擎。 - Ambari和Cloudera Manager等集群管理工具。 - YARN(资源管理引擎)、Mesos(分布式资源调度引擎)、Tachyon(分布式内存文件系统)等。 这些组件共同构成Hadoop的...

    中小型团队.net技术架构选型

    2. **搜索引擎**:在需要快速检索大量数据时,如产品目录或用户信息,引入全文搜索引擎如Elasticsearch或Solr是明智的选择。它们提供高效的数据索引和查询能力,且能很好地与.NET集成。 3. **持续集成/持续部署(CI/...

    超级课程表的技术选型

    - **Elasticsearch**:后来逐渐成为主流选择,具备高扩展性和实时搜索能力。 - **中文分词**:采用MMseg进行中文文本处理,提高搜索精准度。 - **倒排索引**:通过建立倒排索引来加速文档检索速度,减少磁盘I/O操作...

    企业级搜索引擎类程序概要设计模板[整理].pdf

    - 搜索引擎技术:可能采用开源项目如Elasticsearch、Solr等,结合企业的特性和需求进行定制化开发。 - 分布式处理:利用Hadoop或Spark进行大数据处理,提高搜索性能和容错能力。 - 自然语言处理:支持中文分词、...

    qlcms-源码.rar

    5. 搜索功能:通过Elasticsearch或Solr等搜索引擎,实现对内容的快速检索。 三、技术选型 QLCMS的开发很可能基于Spring Boot框架,它简化了Spring应用的初始搭建和运行过程。Spring Cloud也可能被用来实现微服务...

    网上商城carOA

    Elasticsearch或Solr可能用于实现高效的全文搜索功能。 8. **购物车与订单处理**:购物车系统需要管理用户的临时选择,而订单处理则涉及确认、支付、库存更新和物流跟踪等环节。 9. **用户管理与权限控制**:包括...

    springboot105基于保信息学科平台系统设计与实现.zip

    在实现过程中,项目可能会使用Maven或Gradle作为构建工具,集成MyBatis或JPA进行数据访问,使用Thymeleaf或Freemarker处理视图层,利用Elasticsearch或Solr进行全文检索,以及采用Docker进行容器化部署。此外,测试...

    中国移动智能客服系统研究及实现.rar

    技术选型上,可能会选择开源框架如TensorFlow、PyTorch进行模型训练,使用Elasticsearch或Solr构建搜索引擎,用Redis或Memcached进行缓存管理,以及MySQL等数据库存储客户信息和交互记录。这些技术的组合应用,确保...

    springboot242基于SpringBoot的失物招领平台的设计与实现.zip

    5. 使用Elasticsearch或Solr进行全文检索,提高搜索性能。 6. 利用Redis缓存常用数据,减少数据库压力。 五、性能优化与安全考虑 1. 数据库索引优化,提高查询速度。 2. 使用HTTPS协议保证通信安全,防止中间人攻击...

    银行上分布式数据库的最佳实践.docx

    \n- **搜索引擎**:Elasticsearch、Solr用于以搜索为主的业务。\n- **缓存**:Redis Cluster用于高性能的数据缓存需求。\n\n**避免的坑与最佳实践**\n\n1. **稳定性优先**:选择成熟、经过市场验证的分布式数据库...

    java个性化影片推荐系统毕业设计源码 (源代码+论文)

    在实现过程中,开发者可能会采用MySQL等关系型数据库来存储用户信息和影片数据,使用Elasticsearch或Solr进行数据检索和推荐计算,同时利用Redis进行缓存,提高系统的响应速度。除此之外,前端界面可能采用React或...

    架构方案[借鉴].pdf

    例如,使用 Hadoop 或 Spark 进行大数据处理,使用 Elasticsearch 或 Solr 进行搜索服务。 6. **冗余与容错**:为保证高可用性,系统设计应考虑冗余和容错机制。例如,通过主从复制或分布式一致性算法(如 Paxos、...

    基于web的博客系统的设计与实现

    3. **全文搜索**:利用Elasticsearch或Solr等搜索引擎技术,实现高效的全文检索功能。 4. **部署方案**:使用Docker容器化技术,简化部署流程;借助Nginx作为反向代理服务器,提高性能和安全性。 5. **性能优化**:...

    不错的新闻系统

    - 搜索引擎:Elasticsearch或Solr进行全文检索。 - 开发工具:Git进行版本控制,Docker进行容器化部署,Jenkins实现持续集成。 【文件解析】 在提供的文件名中,"helps.htm"可能是帮助文档或用户指南,提供系统...

    基于Java的实例源码-多用户商城电子商务系统.zip

    2. 商品模块:商品发布、分类、搜索、详情展示,可能涉及Solr或Elasticsearch等搜索引擎优化搜索性能。 3. 购物车模块:添加、修改购物车商品,计算总价,可能利用Redis实现会话共享。 4. 订单模块:下单、支付、...

Global site tag (gtag.js) - Google Analytics