Elasticsearch学习笔记(04) - 基本概念:集群、节点、分片和副本

简介

Elasticsearch本身是一个分布式系统,天然支持高可用和水平扩展。站在运维的角度,我们可能更加关注于部署和监控。本章我们将讲述一些核心的、基本的概念 -- 集群、节点、分片和副本。

架构

我们知道,一个可靠的分布式系统必须具有高可用性和可扩展性。

  1. 高可用性
    • 服务可用性 - 允许部分节点停止服务
    • 数据可用性 - 部分节点丢失数据,整个系统不会丢失数据
  2. 可扩展性
    • 请求量的上升、数据量的增加,集群系统有能力将数据分散到各个节点上,从而实现水平扩展

而在Elasticsearch中,其分布式架构又带来了以下好处

  1. 存储的水平扩展
  2. 系统的高可用性,部分节点停止服务,整个集群服务不受影响

Elasticsearch的分布式架构

  1. 不同集群是通过集群名称来区分的,默认集群名称为elasticsearch
  2. 可在配置文件(elasticsearch.yml)中修改集群名称,也可以在启动命令中通过 cluster.name=${clusterName} 指定
  3. 一个集群可以有一个或多个节点

节点

一个节点,其实是一个Elasticsearch的实例。节点本质上是一个Java进程。一台机器可运行多个Elasticsearch进程。但是,在生产环境中,我们建议一台机器运行一个Elasticsearch实例。

每个节点都有自己的名字,可以在配置文件中配置,也可以在启动命令中通过 -E node.name=${nodeName} 指定。

每个节点启动之后,系统会分配一个全局唯一的uid,保存在data目录下。

节点根据其用途和场景,可分为很多种,参考官网的节点说明

1. Master-eligible节点和Master节点

  • 每个节点启动后,默认就是一个Master-eligible节点,但可通过node:master = false来禁止
  • Master-eligible节点可参加选主流程,有机会成为Master节点
  • 当第一个节点启动的时候,它会将自己选举成为Master节点
  • 每个节点都会保存集群的状态,只有Mater节点才可修改集群的状态信息
    1. 集群状态,维护了一个集群中的必要信息,包括:
      • 所有的节点信息
      • 所有的索引及其相关的Mapping和Setting信息
      • 分片的路由信息
    2. 任意节点都能修改信息的话,将导致数据不一致

2. Data节点和Coordinating节点

Data节点,可以保存数据的节点,在数据的水平扩展方面起到了很重要的作用。

Coordinating节点,负责接收客户端请求,并将请求分发到合适的节点,最终又将结果进行汇总。每个节点默认都起到了 Coordinating节点 的作用

3. 其他节点

  1. Hot Node & Warm Node 。又叫冷热节点,比如日志场景
  2. Machine Learning node 。跑机器学习的job
  3. tribe node deprecend 。开始被废弃,使用Cross Cluster Search来代替

4. 节点的配置

  1. 开发环境,一个节点可承担多种角色
  2. 生产环境,应设置单一节点角色
节点类型 配置参数 默认值
master.eligible节点 node.master true
Data节点 node.data true
Ingest节点 node.ingest true
Coordinating节点
Machine Learning节点 node.ml true

分片

在Elasticsearch中,分片分为两种。主分片(Primary shard) & 副本分片(Replica shard)。

  • 主分片,解决了数据水平扩展问题。可以将数据分布到集群内的所有节点
    1. 一个分片就是一个运行的Lucene实例
    2. 主分片数在创建索引时指定,后续不允许修改,除非reindex
  • 副本分片,解决了数据高可用问题
    1. 副本分片数可动态调整
    2. 增加副本分片数,一定程度上可提高服务可用性、读吞吐量等

接下来,我们看一个节点和分片关系的例子。

节点和分片

在这个例子中,我们创建了一个blogs的索引,其主分片数为3,副本分片为1。
同时,我们有3个节点,分别为Node1、Node2、Node3,每个节点都包含一个主分片和副本分片,且当前主分片和当前主分片关联的副本分片并不在同一个节点上。
通过这种机制,即使某一个节点宕掉了,也不会影响整个集群的功能。

【注意】:关于分片数的设定,需要提前做好容量规划。

  • 分片数过小
    1. 后续无法增加节点来实现水平扩展
    2. 单个分片数据量太大,导致数据重新分配耗时
  • 分片数过大。7.0开始,默认主分片数由0更改为1,从而解决了over-sharding的问题
    1. 影响搜索结果相关性分数,影响统计结果的准确性
    2. 单个节点上过多分片,资源浪费,也会影响性能

集群的健康状态

  1. green - 主副分片都正常
  2. yellow - 主分片全部正常分配,副本分片不能正常分配
  3. red - 有主分片不能分配,比如:服务器磁盘容量使用超过85%时,创建一个新的索引

在Kibana中,我们可以通过一些接口来查看集群的信息,包括健康状态、节点、分片等。

通过接口 - GET _cluster/health,我们可以看到集群的健康状态。集群名为clusterName,状态为green,节点数为2,激活的主分片数为6,激活的所有分片数为12。

集群健康状态

通过接口 - GET _cat/nodes,我们可以看到节点的信息

节点信息

通过接口 - GET _cat/shards,我们可以看到分片的信息

分片信息

在Kibana的Stack Monitoring中,我们可以通过直观的UI界面,来比较全面地查看这些信息。

Stack Monitoring

除了Kibana,我们还可以通过监控工具Cerebro来实时查看集群的情况。限于篇幅,本章不讲解Cerebro

总结

本章,我们站在运维的角度,宏观地分析了集群、节点、分片和副本的概念,也了解了查看集群状态的方式,例如Kibana的monitoring、Cerebro等等。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容