宝塔配置Elasticsearch集群发现方法
时间:2026-04-08 20:36:28 143浏览 收藏
在宝塔面板中部署多节点Elasticsearch集群时,节点无法自动发现是常见痛点,根源往往在于7.x+版本必需的discovery.seed_hosts与cluster.initial_master_nodes配置缺失,或6.x及更早版本对multicast的支持未启用;此外,DNS A记录可实现灵活服务发现,而transport端口9300被防火墙拦截更是隐蔽却高频的故障原因——本文系统梳理四大实用方案,手把手教你精准定位、快速打通节点通信,让集群稳稳落地。

如果您在宝塔面板环境下部署了多个Elasticsearch节点,但节点间无法自动识别并组成集群,则可能是由于集群发现机制未正确配置。以下是实现Elasticsearch集群发现的多种配置方法:
一、配置discovery.seed_hosts与cluster.initial_master_nodes
此方法适用于Elasticsearch 7.x及以上版本,通过显式指定初始主节点和种子主机列表,使节点能相互发现并选举主节点。
1、进入宝塔面板,找到Elasticsearch站点对应的安装目录(通常为/www/server/elasticsearch/config/)。
2、编辑elasticsearch.yml文件,在文件末尾添加或修改以下配置项:
3、设置集群名称:cluster.name: my-application(所有节点必须一致)。
4、设置节点名称:node.name: node-1(每台服务器需唯一,如node-2、node-3)。
5、启用网络绑定:network.host: 0.0.0.0(或指定内网IP,避免仅绑定127.0.0.1)。
6、配置发现地址列表:discovery.seed_hosts: ["192.168.1.101:9300", "192.168.1.102:9300", "192.168.1.103:9300"](填写各节点内网IP及transport端口)。
7、指定首次启动时参与主节点选举的节点:cluster.initial_master_nodes: ["node-1", "node-2", "node-3"](节点名须与node.name完全一致)。
二、启用multicast发现(仅限Elasticsearch 6.x及更早版本)
该方式依赖局域网组播通信自动发现节点,无需手动指定IP,但要求网络设备支持且Elasticsearch版本兼容。
1、确认Elasticsearch版本低于7.0(如6.8.23),因7.x已移除multicast插件支持。
2、在elasticsearch.yml中禁用默认单播发现:discovery.zen.ping.unicast.hosts: []。
3、启用multicast发现:discovery.zen.ping.multicast.enabled: true。
4、设置组播地址与端口:discovery.zen.ping.multicast.group: 224.2.2.4 和 discovery.zen.ping.multicast.port: 54328(所有节点保持一致)。
5、确保各服务器防火墙放行UDP端口54328,并关闭NetworkManager对组播的干扰(如启用systemd-networkd则需额外配置)。
三、使用DNS A记录实现服务发现
当节点IP可能动态变化或需解耦配置时,可通过DNS解析统一域名获取全部节点地址,提升可维护性。
1、在内网DNS服务器(或hosts文件)中为每个节点配置A记录,例如:es-node.mydomain.local → 192.168.1.101、es-node.mydomain.local → 192.168.1.102等。
2、在elasticsearch.yml中配置:discovery.seed_hosts: ["es-node.mydomain.local:9300"]。
3、确保所有Elasticsearch节点所在服务器均能通过nslookup或dig解析该域名,并返回全部A记录。
4、验证DNS响应是否包含全部节点IP:dig es-node.mydomain.local @192.168.1.1(替换为实际DNS服务器地址)。
四、配置transport端口与防火墙策略
Elasticsearch节点间通过transport端口(默认9300)通信,若该端口被拦截,集群发现将失败,无论配置如何正确。
1、检查elasticsearch.yml中transport端口是否显式开放:transport.port: 9300(不建议修改,默认即可)。
2、在宝塔面板【安全】页面中,放行TCP端口9300(注意:非9200)。
3、登录各服务器终端,执行:firewall-cmd --permanent --add-port=9300/tcp(CentOS 7+)或 ufw allow 9300(Ubuntu)。
4、重启防火墙服务:firewall-cmd --reload 或 ufw reload。
5、使用telnet或nc测试节点互通性:telnet 192.168.1.102 9300(从node-1执行,目标为node-2)。
今天关于《宝塔配置Elasticsearch集群发现方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
210 收藏
-
235 收藏
-
142 收藏
-
365 收藏
-
287 收藏
-
121 收藏
-
161 收藏
-
186 收藏
-
390 收藏
-
229 收藏
-
337 收藏
-
121 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习