news 2025/12/29 10:04:29

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/21 3:46:28

LobeChat能否接入实时翻译插件?多语言交流解决方案

LobeChat能否接入实时翻译插件?多语言交流解决方案 在跨国团队协作日益频繁的今天,一个中国工程师与德国同事讨论技术方案时,可能正依赖AI助手做实时沟通桥梁;一位留学生在查阅英文论文时,希望对话模型能直接用母语解释…

作者头像 李华
网站建设 2025/12/16 19:01:06

15. 实时数据-SpringBoot集成WebSocket

文章目录 前言一、添加依赖(Maven)二、配置 WebSocket1. 创建 WebSocket 配置类2. 实现 WebSocket 处理器 三、前端测试(HTML JS)四、启动类(标准 Spring Boot 启动类)五、可选:使用 STOMP ove…

作者头像 李华
网站建设 2025/12/16 18:59:52

30、FreeBSD 图形界面配置与 KDE 桌面环境使用指南

FreeBSD 图形界面配置与 KDE 桌面环境使用指南 1. X Window 系统配置 X Window 系统为 FreeBSD 提供了类似于 Windows 的图形用户界面。它与窗口管理器协同工作,为用户打造一个高效的工作环境。 1.1 关键配置文件与程序 XF86Config :这是控制 X Window 系统各种属性的文本…

作者头像 李华
网站建设 2025/12/16 18:59:30

项目中绝对位置和相对位置的具体应用解析

这个通常用于有外部库或者文件输入时,使用相对路径可避免代码复制到别的PC端没法使用的情况基础概念:路径分隔符的作用​在文件系统中,路径用于定位文件或目录的位置。反斜杠 \ 是 Windows 系统中的路径分隔符,而正斜杠 / 通常用于…

作者头像 李华
网站建设 2025/12/16 18:57:17

Doris笔记

Doris常用命令: 查看doris 某用户最大连接数 show property for 用户名 like max_user_connections设置单个用户并发数连接(立即生效) SET PROPERTY FOR 用户名 max_user_connections 500;设置全局的最大并发数连接(所有用户的…

作者头像 李华
网站建设 2025/12/16 18:56:27

ThinkingEngine的首个AI原生能力来了!

移动互联网的普及与社交媒体的蓬勃发展,让用户发声的渠道愈发多元且直接。从国内外主流媒体与社区,到企业社群、客户群等私域场景,这些来自用户自发的、实时的对话,往往直接反映了市场对产品的真实感受、未被满足的潜在需求以及正…

作者头像 李华