Elasticsearch原理学习(三)Elasticsearch基础概念

一、核心概念

1.1 索引(Index)

一个索引由一个名字来标识(必须全部是小写字母),并且当我们要对这个索引中的文档进行索引、搜索、更新和删除的时候,都要使用到这个名字。
一个索引相当于数据库,是多个相似文档的集合。必须通过索引才能进行搜索,使用使用能够极大的提升查询速度,类似于词典里面的目录。

1.2 类型(Type)

在一个索引中,可以定义一种或多种类型。通常会为具有相同字段的文档定义一个类型,是索引上的一个逻辑分区。在不同的elasticsearch中,类型发生了不同的变化。

版本Type
5.x支持多种Type
6.x只有一种Type
7.x默认不在支持自定义的索引类型,默认类型为_doc

1.3 文档(Document)

一个文档是可以被索引的一个基本单元,相当于数据库中的一条数据。
一个index或type中,可以存在任意多个文档。

1.4 字段(Field)

相当于数据库表的字段,每个字段有不同的类型。

1.5 映射(Mapping)

Mapping是对处理数据时的方式和规则作出一定的限制。如字段的类型、默认值、分析器、是否被索引等。
按照最优的映射规则处理数据可以对性能有很大的提升。

1.6 分片(Shards)

分片的存在是为了解决单个索引大量文档的存储问题、以及搜索是响应慢等问题。从而将一个索引划分成了多份,每一份就称之为分片。每个分片也是一个功能完善的“索引”,这个“索引”可以被放置到集群的任意节点上。

分片存在的重要原因有以下两个:
1)允许水平分割扩展容量。
2)允许在分片之上进行分布式的,并行的操作,从而提高其吞吐量。

上面所说的分片其实指的是lucene的索引,一个分片就是一个lucene索引。一个elasticsearch索引就是一个lucene索引的集合。当进行查询时,会将查询请求发送到每一个属于当前elasticsearch索引的分片上,然后将每个分片得到的结果进行合并返回。

1.7 副本(Replicas)

在一个网络 / 云的环境里,失败随时都可能发生,在某个分片/节点不知怎么的就处于离线状态,或者由于任何原因消失了,这种情况下,有一个故障转移机制是非常有用并且是强烈推荐的。为此目的,Elasticsearch 允许你创建分片的一份或多份拷贝,这些拷贝叫做复制分片(副本)。

副本存在的两个重要原因:
1)提高可用性:注意的是副本不能与主/原分片位于同一节点。
2)提高吞吐量:搜索操作可以在所有的副本上并行运行。

1.8 分配(Allocation)

将分片分配给某个节点的过程,包括分配主分片或者副本。如果是副本,还包含从主分片复制数据的过程。这个过程是由 master 节点完成的。

二、系统架构

如下图所示是一个三节点的集群,分片为3,副本是1。其中P表示分片,P0是主分片;R表示副本,R0是主分片副本。系统架构.png

一个运行中的 Elasticsearch 实例称为一个节点,而集群是由一个或者多个拥有相同cluster.name 配置的节点组成, 它们共同承担数据和负载的压力。当有节点加入集群中或者从集群中移除节点时,集群将会重新平均分布所有的数据。

如下所示,模拟一个写请求的数据同步过程:数据同步

流程:
1)当一个写请求发送到node1,当然可能是任意节点。
2)node1节点会计算当前数据写入到哪个分片上,此处我们假设写入到node2的P1分片上。
3)P1分片会将数据同步到它的副本R1上。
4)当所有的操作完成后,每个步骤会返回结果到响应中。

注意:究竟同步几个副本就返回成功是可以设置的。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
你好!关于学习Elasticsearch,我可以给你一些指导。Elasticsearch是一个开源的分布式搜索和分析引擎,主要用于快速、实时地存储、搜索和分析大量数据。下面是一些学习Elasticsearch的步骤: 1. 了解基本概念:开始学习Elasticsearch之前,你需要了解一些基本的概念,比如索引(index)、类型(type)、文档(document)、字段(field)等。这将帮助你更好地理解Elasticsearch的工作原理。 2. 安装和配置:根据你的操作系统,你可以从Elasticsearch官方网站下载并安装合适的版本。安装完成后,你需要进行适当的配置,如设置集群名称、分配内存等。 3. 学习REST API:Elasticsearch提供了丰富的REST API,用于与其进行交互。了解如何使用这些API来索引、搜索和删除数据是学习Elasticsearch的重要一步。 4. 索引和搜索数据:学习如何创建索引、添加文档以及执行搜索操作是使用Elasticsearch的关键。掌握查询语法、过滤器、聚合操作等功能可以帮助你更有效地使用Elasticsearch。 5. 数据建模和分析:学习如何设计合适的数据模型和映射,以及如何使用Elasticsearch进行数据分析和可视化是提高你的技能的重要一步。 6. 扩展和优化:学习如何在生产环境中扩展和优化Elasticsearch集群是非常重要的。了解如何分片、复制、调优性能等将帮助你更好地管理和维护你的数据。 7. 学习资源:除了官方文档,还有很多优秀的学习资源可供参考,如书籍、教程和在线课程等。利用这些资源可以更系统地学习和掌握Elasticsearch。 希望这些步骤能对你学习Elasticsearch有所帮助!如果有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我犟不过你

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值