当前位置: 首页 > news >正文

Elasticsearch 节点角色详解及协调节点请求策略

引言

Elasticsearch 集群中的节点可以承担多种角色,如主节点、数据节点、预处理节点和协调节点。合理配置和理解这些节点角色,对于保障集群的高可用性、性能优化以及请求调度至关重要。本文将深入解析各类节点的职责与配置方式,并介绍如何通过客户端实现请求只发送到协调节点的实践方法,帮助您更好地设计与运维 Elasticsearch 集群架构。

节点种类

一个节点可以同时扮演多个角色,包括 Master Node、Data Node、Coordinating Node 和 Ingest Node。事实上,默认情况下,Elasticsearch 中的所有节点通常都是多角色节点(三个配置默认值都为true),即它们可以同时充当 Master Node、Data Node、Coordinating Node 和 Ingest Node 的角色。这种多角色的配置可以在小规模集群中简化架构,并且在资源有限的情况下有效利用每个节点的能力。

一个节点同时是Master Node、Data Node、Ingest Node。

node.master: true
node.data: true
node.ingest: true

主节点(Master Node)

负责管理集群的状态,包括节点的加入和离开、索引的创建和删除、分片的分配和重分配等。建议配置至少三个 Master Node 作为候选主节点以确保高可用性,一个 ES 集群只能有一个主节点。

node.master: true
node.data: false
node.ingest: false

数据节点(Data Node)

存储实际的数据,并处理所有数据相关的操作,如文档的创建、更新、删除,以及搜索和聚合请求。

node.master: false
node.data: true
node.ingest: false

预处理节点(Ingest Node)

通过预处理管道(Ingest Pipeline)在文档被索引之前对其进行各种处理,例如添加字段、删除字段、修改字段值等。当使用Ingest Pipelines时,Elasticsearch会将文档发送到Ingest Node。

node.master: false
node.data: false
node.ingest: true

协调节点(Coordinating Node)

接收来自客户端的请求,并将这些请求进行请求接收与分发、查询合并以及负载均衡等功能。

node.master: false
node.data: false
node.ingest: false

如何能让请求只发送到协调节点?

如果想请求只发送到协调节点,可以通过RestHighLevelClient创建客户端时指定节点,客户端会轮询这些节点进行请求来实现。

// 创建RestHighLevelClient实例,连接到Elasticsearch集群中的多个节点
RestHighLevelClient client = new RestHighLevelClient(RestClient.builder(new HttpHost("node1.example.com", 9200, "http"), // 集群中的第一个节点new HttpHost("node2.example.com", 9200, "http"), // 集群中的第二个节点new HttpHost("node3.example.com", 9200, "http")  // 集群中的第三个节点)
);

注:官方说,协调节点最好不要单独分离出来,跟数据节点在一起就行。分离开的意义不大。


感谢您的阅读!如果文章中有任何问题或不足之处,欢迎及时指出,您的反馈将帮助我不断改进与完善。期待与您共同探讨技术,共同进步!

相关文章:

  • 课程设计代做网站推荐热搜榜排名今日
  • 长沙网站建设政府补贴怎么学seo基础
  • wordpress 后门检测百度seo刷排名网址
  • 站长工具网站查询网络推广图片大全
  • 跨境电商被骗血本无归网站关键词优化
  • 新浪博客怎么做网站亚洲长尾关键词挖掘
  • PHP轻量级聊天室源码(源码下载)
  • 02. [Python+Golang+PHP]三数之和,多种语言实现最优解demo
  • 4、docker compose
  • 全能邮箱全能邮箱:实现邮件管理的自动化!
  • 学习路之PHP--easyswoole安装入门
  • 基于Python flask 的豆瓣电影top250数据评分可视化
  • 深入解析Kafka JVM堆内存:优化策略与监控实践
  • 基于Python与Flask的新能源汽车可视化大屏系统技术解析
  • 基于Flask实现当当网书籍数据分析大屏
  • Science Robotics 具身智能驱动的空中物理交互新范式:结合形态和传感,与非结构化环境进行稳健交互
  • 一台手机怎样实现多IP上网?方法有多种
  • Kafka 客户端连接机制的一个典型陷阱
  • 企业级调度器LVS (面试版)
  • 第十讲 | 继承
  • day37 python早停策略和模型权重的保存
  • 数据加密技术:守护网络通信安全的基石
  • Linux:五种IO模型
  • 【sgCollapseText】自定义组件:当内容显示不下的时候,折叠展开文本区域。
  • QT6.9中opencv引用路径的其中一种设置
  • 线下ERP与电商平台API接口服务商技术对接全解析