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默认开启了安全认证,不需要额外配置,自动生效。

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

相关推荐
老陈头聊SEO1 小时前
生成引擎优化(GEO)提升数字内容互动与用户体验的新策略
其他·搜索引擎·seo优化
treesforest1 小时前
Ipdatacloud IP 地址查询方案适合哪些场景?
大数据·网络·数据库·网络协议·tcp/ip·ip
Elastic 中国社区官方博客1 小时前
Jina embeddings v3 现已在 Gemini Enterprise Agent Platform Model Garden 上可用
大数据·人工智能·elasticsearch·搜索引擎·ai·全文检索·jina
数智化精益手记局1 小时前
4m变更管理实战:拆解4m变更管理四大要素的管控功能与常见难题
大数据·数据结构·数据库·人工智能·精益工程
DeepSCRM2 小时前
从“断开实体假说”谈起:重构跨域多平台SCRM体系的技术逻辑与实战方案
大数据·重构
财经资讯数据_灵砚智能2 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年4月23日
大数据·人工智能·python·信息可视化·自然语言处理
yuanmazhiwu2 小时前
计算机毕业设计:Python股市行情可视化与ARIMA预测系统 Flask框架 ARIMA 数据分析 可视化 大数据 大模型(建议收藏)✅
大数据·python·数据分析·django·flask·课程设计
Never_every992 小时前
8 个高清 4K 视频素材网址!无水印可商用
大数据·前端·音视频·视频
前端若水2 小时前
Git 撤销与恢复完全指南(超级详细版)
大数据·git·elasticsearch
VBsemi-专注于MOSFET研发定制2 小时前
共享汽车功率管理器件选型实战:空间、效率与可靠性的平衡之道
大数据·汽车