搭建 Elasticsearch 集群:完整教程

本文将详细介绍如何在 Linux 环境下搭建一个 Elasticsearch 集群,涵盖环境准备、配置优化、服务启动等多个环节。


一、环境准备

  1. 创建安装目录

    复制代码
    mkdir /es
    cd /es
  2. 解压 Elasticsearch 安装包

    复制代码
    tar -xzf elasticsearch-7.10.1-linux-x86_64.tar.gz -C /es
  3. 配置环境变量 编辑 ~/.bashrc 文件,加入以下内容:

    复制代码
    export JAVA_HOME=/es/elasticsearch-7.10.1/jdk
    export ES_JAVA_HOME=/es/elasticsearch-7.10.1/jdk
    export CLASSPATH=$JAVA_HOME/lib
    export PATH=$JAVA_HOME/bin:$PATH

    执行以下命令以生效:

    复制代码
    source ~/.bashrc
  4. 创建运行用户和分配权限

    复制代码
    groupadd es
    useradd es -g es -p 12345678
    chown -R es:es /es/elasticsearch-7.10.1/

二、配置 Elasticsearch

  1. 修改配置文件 编辑 /es/elasticsearch-7.10.1/config/elasticsearch.yml

    复制代码
    cluster.name: my-application
    node.name: node-2
    path.data: /data/data
    path.logs: /data/logs
    network.host: 0.0.0.0
    network.publish_host: 172.16.0.80
    node.attr.ip: 172.16.0.80
    http.port: 9200
    discovery.seed_hosts: ['172.16.0.80','172.16.0.26','172.16.0.250']
    cluster.initial_master_nodes: ['node-1', 'node-2', 'node-3']
    action.destructive_requires_name: true
    node.roles: [master, data]
  2. 挂载数据盘

    复制代码
    lsblk
    mkfs.ext4 /dev/vdb
    mount /dev/vdb /data
    lsblk
    chown -R es:es /data/
  3. 调整虚拟内存 编辑 /etc/sysctl.conf 文件,添加以下内容:

    复制代码
    vm.max_map_count = 262144

    立即生效:

    复制代码
    sysctl -p

三、启动服务

  1. 以运行用户启动 Elasticsearch 切换到 es 用户并启动服务:

    复制代码
    su es
    ./elasticsearch -d
  2. 验证集群节点状态 使用以下命令查看节点状态:

    复制代码
    curl -X GET "localhost:9200/_cat/nodes?v&h=ip,node.role,name"

四、附加说明

  1. 修复权限问题 如果运行过程中出现权限问题,可以执行以下命令:

    复制代码
    chown -R es:es /es/elasticsearch-7.10.1/
    chown -R es:es /data
    chmod +x /es/elasticsearch-7.10.1/jdk/jre/bin/java

通过上述步骤,您应该能够成功搭建并运行一个 Elasticsearch 集群。希望本文对您有所帮助!如有问题,欢迎留言讨论。


相关推荐
JAVA面经实录9174 小时前
Elasticsearch 完整版完整知识体系
java·elasticsearch·搜索引擎·es
代码讲故事5 小时前
在没有kibana的ES(elasticsearch)线上生产环境集群中,如何通过命令行修改或增加字段而不需要reindex?
大数据·elasticsearch·搜索引擎·命令行·es·索引·模版
yurenpai(27届找实习中)7 天前
Elasticsearch 核心总结 + 面试题实战(黑马点评项目)
redis·es
徐小青青啊9 天前
es集群不中断实时数据更新损坏节点硬盘
大数据·elasticsearch·搜索引擎·es
醇氧11 天前
【Hermes Agent】使用阿里云百炼 Token Plan(方式一:命令行一键配置)
阿里云·云计算·es·openclaw
RemainderTime1 个月前
基于Spring AI + 阿里百炼 DashScope:构建 AI Agent RAG 企业级知识助手
人工智能·后端·spring·ai·es
Johnstons1 个月前
Wireshark 和 tcpdump 到底怎么选?网络故障排查实战中的边界、判断标准与落地清单
wireshark·php·es·tcpdump·抓包分析·抓包与协议分析工具选型
Johnstons1 个月前
TCP Reset(RST)异常是什么?一文讲透连接被动中断的识别方法、适用场景、与超时断开的边界及排查清单
网络协议·tcp/ip·php·es·抓包分析
Johnstons1 个月前
Wireshark ExpertInfo是什么?一文讲透异常分级、适用场景、和传统抓包阅读的区别与排查标准
网络·测试工具·wireshark·es
Johnstons2 个月前
网络故障定位工具怎么搭配:Wireshark、tcpdump、监控平台各自该在什么时候上场?
数据分析·wireshark·php·es·tcpdump·网络故障定位工具搭配与选型