机器准备

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默认开启了安全认证,不需要额外配置,自动生效。
配套资料,有需要的小伙伴可以联系博主获取