Linux搭建ElasticSearch(ES)集群并设置密码登录_es集群设置登录密码-程序员宅基地

技术标签: 1024程序员节  elasticsearch  

1. 环境信息

操作系统:CentOS7或者Amazon Linux 2

内核架构:x86_64

ElasticSearch版本:6.8.10

JDK版本:8u351

本次搭建的3台服务器IP地址:

ES节点 IP地址
es-node1 172.16.1.21
es-node2 172.16.1.22
es-node3 172.16.1.23

安装目录:/data

2. 下载ES安装包

在3台服务器上各自下载tar.gz包:

wget  https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.8.10.tar.gz

也可以在官网中下载,下载地址Elasticsearch 6.8.10 | Elastic

 解压安装包至/data目录:

tar -zxvf elasticsearch-6.8.10.tar.gz -C /data

3. 安装JDK

在3台服务器上各自下载rpm包

JDK官网地址:

https://www.oracle.com/java/technologies/javase-jdk11-downloads.html

注意:需要登录Oracle才能下载,可以注册一个账号使用。

选择JAVA8中的Linux 64位的rpm包,点击下载

 将下载的JDK安装包上传至服务器/data/software目录,然后rpm直接安装JDK:

rpm -ivh /data/software/jdk-8u351-linux-x64.rpm

完成后输入java -version可以看到以下输出:

配置java环境变量:

vim /etc/profile

在末尾增加以下内容:

export JAVA_HOME=/usr/java/jdk1.8.0_351-amd64
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin

wq保存退出后,输入命名生效:

source /etc/profile

3. 搭建ElasticSearch集群

解压完成后,ES的目录为/data/elasticsearch-6.8.10

创建数据目录、日志目录:

mkdir -p /data/elasticsearch-6.8.10/data
mkdir -p /data/elasticsearch-6.8.10/logs

配置修改

编辑elasticsearch.yml,开始修改ElasticSearch集群的配置,3台服务器上的配置不同。

vim /data/elasticsearch-6.8.10/config/elasticsearch.yml

其中,服务器1配置如下:

cluster.name: es-cluster    #集群名称
node.name: es-node1    #当前节点名称
node.master: true    #允许当前节点作为master主节点
node.data: true

path.data: /data/elasticsearch-6.8.10/data    #ES集群数据目录
path.logs: /data/elasticsearch-6.8.10/logs    #ES集群日志目录

network.host: 0.0.0.0    #配置0.0.0.0允许其他地址访问
http.port: 9200    #对外访问端口
transport.tcp.port: 9300
transport.tcp.compress: true

discovery.zen.ping.unicast.hosts: ["172.16.1.21", "172.16.1.22", "172.16.1.23"]    #集群的所有节点的IP地址
discovery.zen.minimum_master_nodes: 2    #集群正常运行的节点数量,一般为半数+1
discovery.zen.ping_timeout: 3s    #集群节点发现超时时间

http.cors.enabled: true    #允许跨域访问
http.cors.allow-origin: "*"

#以下配置用于设置密码访问ES集群,如不需要可以不用
xpack.security.enabled: true
xpack.license.self_generated.type: basic
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate
xpack.security.transport.ssl.keystore.path: elastic-certificates.p12
xpack.security.transport.ssl.truststore.path: elastic-certificates.p12

服务器2配置如下:

cluster.name: es-cluster
node.name: es-node2    #节点名称,集群内各个节点名称唯一
node.master: true
node.data: true

path.data: /data/elasticsearch-6.8.10/data
path.logs: /data/elasticsearch-6.8.10/logs

network.host: 0.0.0.0
http.port: 9200
transport.tcp.port: 9300
transport.tcp.compress: true

discovery.zen.ping.unicast.hosts: ["172.16.1.21", "172.16.1.22", "172.16.1.23"] 
discovery.zen.minimum_master_nodes: 2
discovery.zen.ping_timeout: 3s

http.cors.enabled: true
http.cors.allow-origin: "*"

#以下配置用于设置密码访问ES集群,如不需要可以不用
xpack.security.enabled: true
xpack.license.self_generated.type: basic
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate
xpack.security.transport.ssl.keystore.path: elastic-certificates.p12
xpack.security.transport.ssl.truststore.path: elastic-certificates.p12

服务器3配置如下:

cluster.name: es-cluster
node.name: es-node3    #节点名称,集群内各个节点名称唯一
node.master: true
node.data: true

path.data: /data/elasticsearch-6.8.10/data
path.logs: /data/elasticsearch-6.8.10/logs

network.host: 0.0.0.0
http.port: 9200
transport.tcp.port: 9300
transport.tcp.compress: true

discovery.zen.ping.unicast.hosts: ["172.16.1.21", "172.16.1.22", "172.16.1.23"] 
discovery.zen.minimum_master_nodes: 2
discovery.zen.ping_timeout: 3s

http.cors.enabled: true
http.cors.allow-origin: "*"

#以下配置用于设置密码访问ES集群,如不需要可以不用
xpack.security.enabled: true
xpack.license.self_generated.type: basic
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate
xpack.security.transport.ssl.keystore.path: elastic-certificates.p12
xpack.security.transport.ssl.truststore.path: elastic-certificates.p12

其他配置修改,主要是修改jvm的运行内存大小,可以根据实际情况按需修改:

vim /data/elasticsearch-6.8.10/config/jvm.options

修改其中的以下两条,根据实际情况按需修改:

-Xms1g
-Xmx1g

系统参数修改:

vim /etc/security/limits.conf

在末尾增加以下内容:

*                soft    nofile          65536
*                hard    nofile          65536
*                soft    nproc           4096
*                hard    nproc           4096

修改/etc/sysctl.conf配置:

vim /etc/sysctl.conf
vm.max_map_count=655360

修改完成保存生效:

sysctl -p

运行用户创建

由于ES集群不允许root用户运行,需要创建ES运行用户:

# 创建用户组
groupadd es
# 创建用户并添加至用户组
useradd es -g es 
# 更改用户密码(输入 es)
passwd es

修改目录权限:

sudo chown -R es:es  /data/elasticsearch-6.8.10

切换用户:

su es

至此安装ElasticSearch集群就结束了,不需要开启密码访问的话,就可以直接启动3台服务器的ES集群服务了。

启动服务

cd /data/elasticsearch-6.8.10/bin
./elasticsearch -d    #-d是后台启动,第一次启动时可以不加-d,查看启动的日志情况

启动后输入jps可以查看到服务状态

3台节点都启动完成后,可以在浏览器访问http://节点IP地址:9200/_cat/health?v查看集群状态

 也可以直接访问http://节点IP地址:9200查看服务情况

开启密码访问

在服务器1上生成 TLS 和身份验证,将会在 config 下生成 elastic-certificates.p12 文件,将此文件传到其他两个节点的 config 目录,注意文件权限

cd /data/elasticsearch-6.8.10
bin/elasticsearch-certutil cert -out config/elastic-certificates.p12 -pass ""

将 config目录下的elastic-certificates.p12文件上传至其他2台服务器的config目录下。

重启ElasticSearch服务,3台服务器都需要执行:

jps    #查询ES服务进程号
kill -9 xxx    #杀掉ES进程,关闭服务

cd /data/elasticsearch-6.8.10/bin
./elasticsearch -d    #启动服务

设置密码,在服务器1上执行命令:

cd /data/elasticsearch-6.8.10
bin/elasticsearch-setup-passwords interactive

随后按照提示依次输入elastic、apm_system、kibana、logstash_system、beats_system、remote_monitoring_user这6个用户的密码,完成后数据会自动同步至其他2个节点。

再次在浏览器中访问ES,http://ip地址:9200,就可以看到需要用户名密码访问了。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_61418822/article/details/127497471

智能推荐

python智慧交通大数据系统 实时监控 Flask框架 可视化(源码)_python技术在智慧交通大树后监控平台中的实时监控应用研究-程序员宅基地

文章浏览阅读905次,点赞23次,收藏11次。python智慧交通大数据系统 实时监控 Flask框架 可视化(源码)_python技术在智慧交通大树后监控平台中的实时监控应用研究

浅谈“三层结构”原理与用意(转帖)-程序员宅基地

文章浏览阅读78次。浅谈“三层结构”原理与用意序在刚刚步入“多层结构”Web应用程序开发的时候,我阅读过几篇关于“asp.net三层结构开发”的文章。但其多半都是对PetShop3.0和Duwamish7的局部剖析或者是学习笔记。对“三层结构”通体分析的学术文章几乎没有。2005年2月11日,Bincess BBS彬月论坛开始试运行。不久之后,我写了一篇题目为《浅谈“三层结构”原理与用意》的文章。旧版文...

RITSEC CTF2021 Forensics1597题解记录-程序员宅基地

文章浏览阅读300次。题目地址:http://git.ritsec.club:7000/1597.git/这是一道与git版本管理有关的题目解题过程:一、很明显第一步将远程仓库克隆到本地git clone http://git.ritsec.club:7000/1597.git/其中一共有两个文件打开后发现flag.txt为空文件,README.md文件显示:# 1597A git challenge series? Sounds fun.没有用!!!二、推测(看大佬WP)查看版本记录。1.mkdir ki_ritsec

ssm 课程资源库APP 计算机毕设源码23834-程序员宅基地

文章浏览阅读70次。主要包括系统总体结构设计、系统数据结构设计、系统功能设计和系统安全设计等:详细设计主要包括模块实现的关键代码,系统数据库访问和主要功能模块的具体实现等。最后对系统进行功能测试,并对测试结果进行分析总结,及时改进系统中存在的不足,为以后的系统维护提供了方便,也为今后开发类似系统提供了借鉴和帮助。本课程资源库APP采用的数据库是Mysql,使用Java技术开发。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点......

G711/G726编解码示例_g711a s16le 编码格式-程序员宅基地

文章浏览阅读3.3k次。概述本文基于ffmpeg,演示g711a,g711u,g726,g726le的编码以及编码后的文件如何播放测试。g711本质还是pcm,不过是将16位带符号pcm数据压缩为8位pcm数据。g711a是取s16le格式的高13位;g711u则是取s16le格式的高14位。实际压缩比是2:1,具体压缩算法可参考如下博客:https://blog.csdn.net/q2519008/article/..._g711a s16le 编码格式

element-ui table 表头合并_element table 合并表头-程序员宅基地

文章浏览阅读2.9k次,点赞2次,收藏10次。element-ui table 表头合并方法实操如下:现在:期望:代码: <el-table ref="tableRef" v-loading="loadingTab" class="table" :data="tableData" height="100%" size="mini" border :span-method="spanMethod" :header-cell-style="headerStyle"> <el-table-colum..._element table 合并表头

随便推点

Elasticsearch的基础概念和配置实战-程序员宅基地

文章浏览阅读3.7k次。作者:禅与计算机程序设计艺术 1.简介Elasticsearch是一个开源分布式搜索及分析引擎,主要面向云计算环境和实时应用场景。在互联网行业中扮演着越来越重要的角色,从而影响到各个领域,包括IT、电子商务、金融、搜索等。本文将以实战的方式,带领读者了解Elastic Stack(El

Python入门实战:Python的人工智能应用-程序员宅基地

文章浏览阅读11次。1.背景介绍Python是一种高级、通用、解释型的编程语言,它具有简单易学、高效开发、可读性强等优点,因此在各个领域得到了广泛应用。在人工智能领域,Python也是最受欢迎的编程语言之一。Python的人工智能库和框架丰富,包括NumPy、Pandas、Scikit-learn、TensorFlow、PyTorch等,这些库和框架提供了丰富的功能和强

uni-app 开发微信小程序 自定义tabBar_uniapp iconpath-程序员宅基地

文章浏览阅读1.4k次。uni-app 微信小程序 自定义tabBar 底部导航_uniapp iconpath

wordpress 自定义_在WordPress中创建自定义的“降雪”设计-程序员宅基地

文章浏览阅读327次。wordpress 自定义In December 2012, the New York Times broke out of their standard online post layout and wowed us with John Branch’s beautiful “Snow Fall” article. Instead of simply containing headings, t..._wordpress have_rows

C语言如何输入带空格的字符串?_c语言输入带空格的字符串-程序员宅基地

文章浏览阅读3.6w次,点赞84次,收藏201次。C/C++输入带空格的字符串_c语言输入带空格的字符串

MySQL DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci utf8mb4_bin utf8mb4_general_ci-程序员宅基地

文章浏览阅读1.5w次,点赞10次,收藏40次。在mysql中执行show create table <tablename>指令,可以看到一张表的建表语句,example如下:CREATE TABLE `table1` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `field1` text COLLATE utf8_unicode_ci NOT NULL COMMENT '字段1', `field2` varchar(128) COLLATE ..._collate=utf8mb4_unicode_ci

推荐文章

热门文章

相关标签