Elasticsearch集群搭建

机器准备

1、配置host解析

末尾添加如下配置

复制代码
10.10.10.100 xiaobai-vm-100
10.10.10.101 xiaobai-vm-101
10.10.10.102 xiaobai-vm-102

2、禁用swap

复制代码
vim /etc/fstab

分别注释这一行

修改后重启

查看是否生效

为0B则生效

3、下载安装包

版本选择:8.18.2

注意:elk全家桶版本选择要一致

下载地址:https://www.elastic.co/downloads/past-releases/elasticsearch-8-18-2

根据不同平台下载elasticsearch、kibana、ik分词器

将下载好的elasticsearch、ik分词器压缩包上传至3台机器,将kibana压缩包上传至任意一台机器,小白传到10.10.10.100机器上

4、解压elasticsearch,将三台机器的elasticsearch压缩包分别解压到/opt目录下

5、将ik分词器解压到cd /opt/elasticsearch-8.18.2/plugins目录下

复制代码
cd /opt/elasticsearch-8.18.2/plugins/
mkdir analysis-ik
mv /root/elasticsearch-analysis-ik-8.18.2.zip ./analysis-ik/
cd analysis-ik/
unzip elasticsearch-analysis-ik-8.18.2.zip
rm -rf elasticsearch-analysis-ik-8.18.2.zip

6、创建用户、授权

由于elasticsearch不允许root用户启动,则创建用户并授权

三台机器同时执行

复制代码
cd /opt
useradd es
mkdir /home/es
chown -R es:es /opt/elasticsearch-8.18.2/

7、启动主节点

将10.10.10.100规定为主节点,执行

复制代码
cd /opt/elasticsearch-8.18.2/
vim config/elasticsearch.yml

修改为以下配置

复制代码
# ---------------------------------- Cluster -----------------------------------
#
# Use a descriptive name for your cluster:
#
cluster.name:xiaobai-elasticsearch-cluster
#
# ------------------------------------ Node ------------------------------------
#
# Use a descriptive name for the node:
#
node.name:xiaobai-vm-100
# ---------------------------------- Network -----------------------------------
network.host:0.0.0.0
cluster.initial_master_nodes:["xiaobai-vm-100"]
http.cors.enabled:true
http.cors.allow-origin:"*"

执行如下命令启动es

复制代码
su es
./bin/elasticsearch -d

等待启动成功自动退出日志,回到终端

修改es的密码,修改为123456

复制代码
./bin/elasticsearch-reset-password -u elastic -i

查看集群信息

访问:https://10.10.10.100:9200/_cat/nodes

弹出用户名密码为:elastic/123456

8、启动其他节点

主节点生成token

在主节点(10.10.10.100)执行

复制代码
./bin/elasticsearch-create-enrollment-token -s node

修改其他节点配置文件,非主节点执行

复制代码
cd /opt/elasticsearch-8.18.2/
vim config/elasticsearch.yml

修改为以下配置

10.10.10.101

复制代码
# ---------------------------------- Cluster -----------------------------------
#
# Use a descriptive name for your cluster:
#
cluster.name:xiaobai-elasticsearch-cluster
#
# ------------------------------------ Node ------------------------------------
#
# Use a descriptive name for the node:
#
node.name:xiaobai-vm-101
# ---------------------------------- Network -----------------------------------
network.host:0.0.0.0
http.cors.enabled:true
http.cors.allow-origin:"*"

10.10.10.102

复制代码
# ---------------------------------- Cluster -----------------------------------
#
# Use a descriptive name for your cluster:
#
cluster.name:xiaobai-elasticsearch-cluster
#
# ------------------------------------ Node ------------------------------------
#
# Use a descriptive name for the node:
#
node.name:xiaobai-vm-102
# ---------------------------------- Network -----------------------------------
network.host:0.0.0.0
http.cors.enabled:true
http.cors.allow-origin:"*"

保存退出

两台机器执行

复制代码
su es
./bin/elasticsearch --enrollment-token eyJ2ZXIiOiI4LjE0LjAiLCJhZHIiOlsiMTAuMTAuMTAuMTAwOjkyMDAiXSwiZmdyIjoiYzY3MzQ4NGVmZWJlM2M4NzdhMmFhMDY0MzllMTM4YjJiYzc2NDRkZWUwOWE5Nzc1MzczNDdiODYxMTdhODZkNCIsImtleSI6IlpUU3o0SmtCdVEyVHpVanNzTkZrOi1TSmd3eXRVQUYwbXBOYi0tQ1Z1RlEifQ== -d

同样等待启动成功自动回到终端

访问:https://10.10.10.100:9200/_cat/nodes

可以看到3台节点启动完毕

9、主节点启动kibana

10.10.10.100终端执行,切换root用户时输入root用户密码

将kibana压缩包解压到/opt

复制代码
su root
cd /root
tar -zxvf kibana-8.18.2-linux-x86_64.tar.gz -C /opt

同样kibana也不允许root用户启动,授权

复制代码
cd /opt
chown -R es:es /opt/kibana-8.18.2/

修改kibana的配置文件

复制代码
cd kibana-8.18.2/
vim config/kibana.yml

修改为如下内容

复制代码
server.port: 5601
server.host: "10.10.10.100"
elasticsearch.hosts: ["http://xiaobai-vm-100:9200", "http://xiaobai-vm-101:9200", "http://xiaobai-vm-102:9200"]
i18n.locale: "zh-CN"

保存退出

使用es脚本生成kibana的token

复制代码
cd /opt/elasticsearch-8.18.2/
./bin/elasticsearch-create-enrollment-token -s kibana

进入kibana目录

复制代码
cd /opt/kibana-8.18.2/
su es

设置kibana

复制代码
./bin/kibana-setup --enrollment-token eyJ2ZXIiOiI4LjE0LjAiLCJhZHIiOlsiMTAuMTAuMTAuMTAwOjkyMDAiXSwiZmdyIjoiYz

启动

复制代码
nohup ./bin/kibana > logs/kibana.log 2>&1 &

查看启动日志

复制代码
cd logs
tail -f kibana.log

访问测试:http://10.10.10.100:5601/

账号密码:elastic/123456

这样一个三节点带有安全认证的elasticsearch集群就搭建好了,elasticsearch8默认开启了安全认证,不需要额外配置,自动生效。

配套资料,有需要的小伙伴可以联系博主获取

相关推荐
元拓数智14 小时前
AI 自动化工作流,正在重塑企业数据工程的效率边界
大数据·人工智能·ai·自动化·工作流·数据工程
xwz小王子14 小时前
机器人学习十年进化史——从强化学习到VLA的范式变迁
大数据·学习·机器人
老詹图解IT15 小时前
银河麒麟V10(Kylin V10 SP1/SP3)常见报错对照表—2026年5月版
大数据·kylin
MARSERERER15 小时前
StarRocks如何开启FQDN域名访问
大数据
CableTech_SQH16 小时前
华中科技大学同济医学院附属协和医院重庆医院智能化建设 F5G 全光方案百盛分析报告
大数据·网络·5g·运维开发·信息与通信
陆水A16 小时前
用CASE WHEN实现横向迭代,节点数据串行推算
大数据·数据仓库·数据库开发·etl·etl工程师
3D探路人16 小时前
模灵 大模型聚合API 转发流程技术实现
java·大数据·开发语言·前端·人工智能·计算机视觉
城事漫游Molly17 小时前
案例研究:如何明智地选择案例、精巧地界定边界、深刻地进行分析?
大数据·人工智能·ai写作·论文笔记
LaughingZhu17 小时前
Product Hunt 每日热榜 | 2026-05-12
大数据·人工智能·经验分享·神经网络·产品运营
eastyuxiao18 小时前
数字孪生(Digital Twin)从入门到实战教程
大数据·人工智能·数字孪生