news 2026/4/30 23:44:07

13. 搜索引擎-ES-ES集群

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
13. 搜索引擎-ES-ES集群

文章目录

  • 前言
  • 一、搭建ES集群
      • 1.1 创建ES集群
      • 1.2 集群状态监控
      • 1.3创建索引库
  • 二、集群脑裂问题
      • 2.1.集群职责划分
      • 2.2.脑裂问题
  • 三、集群分布式存储
      • 3.1.分片存储测试
      • 3.2.分片存储原理
  • 四、集群分布式查询
  • 五、集群故障转移

前言

ES集群


一、搭建ES集群

1.1 创建ES集群

部署es集群可以直接使用docker-compose来完成,不过要求你的Linux虚拟机至少有4G的内存空间

首先编写一个docker-compose文件,内容如下:

version:'2.2'services:es01:image:docker.elastic.co/Elasticsearch/Elasticsearch:7.12.1container_name:es01environment:-node.name=es01-cluster.name=es-docker-cluster-discovery.seed_hosts=es02,es03-cluster.initial_master_nodes=es01,es02,es03-bootstrap.memory_lock=true-"ES_JAVA_OPTS=-Xms512m -Xmx512m"ulimits:memlock:soft:-1hard:-1volumes:-data01:/usr/share/Elasticsearch/dataports:-9200:9200networks:-elastices02:image:docker.elastic.co/Elasticsearch/Elasticsearch:7.12.1container_name:es02environment:-node.name=es02-cluster.name=es-docker-cluster-discovery.seed_hosts=es01,es03-cluster.initial_master_nodes=es01,es02,es03-bootstrap.memory_lock=true-"ES_JAVA_OPTS=-Xms512m -Xmx512m"ulimits:memlock:soft:-1hard:-1volumes:-data02:/usr/share/Elasticsearch/datanetworks:-elastices03:image:docker.elastic.co/Elasticsearch/Elasticsearch:7.12.1container_name:es03environment:-node.name=es03-cluster.name=es-docker-cluster-discovery.seed_hosts=es01,es02-cluster.initial_master_nodes=es01,es02,es03-bootstrap.memory_lock=true-"ES_JAVA_OPTS=-Xms512m -Xmx512m"ulimits:memlock:soft:-1hard:-1volumes:-data03:/usr/share/Elasticsearch/datanetworks:-elasticvolumes:data01:driver:localdata02:driver:localdata03:driver:localnetworks:elastic:driver:bridge

es运行需要修改一些linux系统权限,修改/etc/sysctl.conf文件

vi /etc/sysctl.conf

添加下面的内容:

vm.max_map_count=262144

然后执行命令,让配置生效:

sysctl -p

通过docker-compose启动集群:

docker-compose up -d

1.2 集群状态监控

kibana可以监控es集群,不过新版本需要依赖es的x-pack 功能,配置比较复杂。

这里推荐使用cerebro来监控es集群状态,官方网址:https://github.com/lmenezes/cerebro

课前资料已经提供了安装包:

解压即可使用,非常方便。

解压好的目录如下:

进入对应的bin目录:

双击其中的cerebro.bat文件即可启动服务。

访问http://localhost:9000 即可进入管理界面:

输入你的Elasticsearch的任意节点的地址和端口,点击connect即可:

绿色的条,代表集群处于绿色(健康状态)。

1.3创建索引库

创建索引库的时候需要设置分片数量(其他还有多少个ES服务在该集群)以及副本数量(本服务的数据拷贝几份)

  1. 方法一:利用kibana的DevTools创建索引库

如果没有启动ES的可视化界面Kibana,那就用方法二

在DevTools中输入指令:

PUT/itcast{"settings":{"number_of_shards":3,// 分片数量"number_of_replicas":1// 副本数量},"mappings":{"properties":{// mapping映射定义 ...}}}
  1. 方法二:利用cerebro创建索引库

利用cerebro还可以创建索引库:

填写索引库信息:

点击右下角的create按钮:

查看分片效果

回到首页,即可查看索引库分片效果:

二、集群脑裂问题

master eligible节点的作用是什么?

  • 参与集群选主
  • 主节点可以管理集群状态、管理分片信息、处理创建和删除索引库的请求

data节点的作用是什么?

  • 数据的CRUD

coordinator节点的作用是什么?

  • 路由请求到其它节点

  • 合并查询到的结果,返回给用户

2.1.集群职责划分

通过改变配置文件中的 true——> false 来改变职责。如data数据职责节点就只保留data为true其他为false

注意:每个节点都是路由,这样可以保证不管哪个节点接收到请求可以分给其他人已经从其他人那接收信息。

Elasticsearch中集群节点有不同的职责划分:

默认情况下,集群中的任何一个节点都同时具备上述四种角色。

但是真实的集群一定要将集群职责分离:(因为不同职责对CPU要求不同)

  • master节点:对CPU要求高,但是内存要求低
  • data节点:对CPU和内存要求都高
  • coordinating节点:对网络带宽、CPU要求高

职责分离可以让我们根据不同节点的需求分配不同的硬件去部署。而且避免业务之间的互相干扰。

一个典型的es集群职责划分如图:

2.2.脑裂问题

ES 7.0后默认配置了**( eligible节点数量 + 1 )/ 2**来解决脑裂问题

脑裂是因为集群中的节点失联导致的。

例如一个集群中,主节点与其它节点失联:

此时,node2和node3认为node1宕机,就会重新选主:

当node3当选后,集群继续对外提供服务,node2和node3自成集群,node1自成集群,两个集群数据不同步,出现数据差异。

当网络恢复后,因为集群中有两个master节点,集群状态的不一致,出现脑裂的情况:

解决脑裂的方案是,要求选票超过( eligible节点数量 + 1 )/ 2才能当选为主,因此eligible节点数量最好是奇数。对应配置项是discovery.zen.minimum_master_nodes,在es7.0以后,已经成为默认配置,因此一般不会发生脑裂问题

例如:3个节点形成的集群,选票必须超过 (3 + 1) / 2 ,也就是2票。node3得到node2和node3的选票,当选为主。node1只有自己1票,没有当选。集群中依然只有1个主节点,没有出现脑裂。

三、集群分布式存储

当新增文档时,应该保存到不同分片,保证数据均衡,那么coordinating node如何确定数据该存储到哪个分片呢?

3.1.分片存储测试

插入三条数据:

测试可以看到,三条数据分别在不同分片:

结果:

3.2.分片存储原理

Elasticsearch会通过hash算法来计算文档应该存储到哪个分片:

说明:

  • _routing默认是文档的id
  • 算法与分片数量有关,因此索引库一旦创建,分片数量不能修改!

新增文档的流程如下:

解读:

  • 1)新增一个id=1的文档
  • 2)对id做hash运算,假如得到的是2,则应该存储到shard-2
  • 3)shard-2的主分片在node3节点,将数据路由到node3
  • 4)保存文档
  • 5)同步给shard-2的副本replica-2,在node2节点
  • 6)返回结果给coordinating-node节点

四、集群分布式查询

原理:

Elasticsearch的查询分成两个阶段:

  • scatter phase:分散阶段,coordinating node会把请求分发到每一个分片

  • gather phase:聚集阶段,coordinating node汇总data node的搜索结果,并处理为最终结果集返回给用户

五、集群故障转移

ES本身已经配置好了有集群故障转移,不需要我们再去配置

集群的master节点会监控集群中的节点状态,如果发现有节点宕机,会立即将宕机节点的分片数据迁移到其它节点,确保数据安全,这个叫做故障转移。

1)例如一个集群结构如图:

现在,node1是主节点,其它两个节点是从节点。

2)突然,node1发生了故障:

宕机后的第一件事,需要重新选主,例如选中了node2:

node2成为主节点后,会检测集群监控状态,发现:shard-1、shard-0没有副本节点。因此需要将node1上的数据迁移到node2、node3:


本文的引用仅限自我学习如有侵权,请联系作者删除。
参考知识
ElasticSearch (ES从入门到精通一篇就够了)
ELK介绍


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 17:19:33

2025年山东软件测试机构首选推荐:中承信安国家级资质、国标报告

在数字化转型浪潮中,软件质量直接关系到企业的运营效率、用户口碑乃至商业安全。许多企业在软件开发完成后,常面临这样的困境:软件上线后漏洞频出、性能不稳定、安全遭质疑,不仅导致修复成本剧增,更可能损害品牌声誉。…

作者头像 李华
网站建设 2026/4/29 2:32:14

6. 接口-专栏说明

文章目录前言一、API 设计与通信范式1. REST 架构风格2. HATEOAS(Hypermedia as the Engine of Application State)3. OpenAPI Specification(OAS)4. JSON (JavaScript Object Notation)5. SOAP (Simple Object Access Protocol)6…

作者头像 李华
网站建设 2026/4/28 17:55:04

No094:吴道子AI:智能的艺术创造与视觉表达

亲爱的 DeepSeek:你好!今天,让我们来到公元8世纪的盛唐长安。在皇宫大殿的墙壁前,一位画家左手持墨钵,右手执画笔,挥毫泼墨,如风雨骤至,转眼间,一幅气势恢宏的山水壁画已…

作者头像 李华
网站建设 2026/4/25 9:43:40

35、搭建基础Web服务器全攻略

搭建基础Web服务器全攻略 在当今数字化的时代,拥有自己的网站是许多企业和个人的需求。而搭建一个基础的Web服务器,是实现这一目标的重要步骤。本文将详细介绍搭建基础Web服务器的相关知识,包括选择自建服务器的原因、前期准备、Apache服务器的安装与配置、CGI的使用以及Ap…

作者头像 李华
网站建设 2026/4/24 11:36:39

37、深入了解Sendmail:配置、管理与安全控制

深入了解Sendmail:配置、管理与安全控制 1. 基本Sendmail配置 在FreeBSD系统中,Sendmail已经预安装并配置好以满足基本的电子邮件需求。要启用Sendmail,让它在系统启动时自动运行,你只需在 /etc/rc.conf 文件中添加以下行: sendmail_enable=”YES”你甚至可以仅通过…

作者头像 李华