当前位置: 首页 > article >正文

从单机到集群:手把手教你用ES 7.10.0自带JDK搭建多节点测试环境

从单机到集群手把手教你用ES 7.10.0自带JDK搭建多节点测试环境在当今数据驱动的时代ElasticsearchES作为一款开源的分布式搜索和分析引擎已经成为许多企业和开发者处理海量数据的首选工具。对于开发者和测试人员而言能够在本地快速搭建一个多节点的ES集群环境不仅有助于深入理解ES的分布式特性还能为后续的性能测试、功能验证提供便利。本文将带你从零开始利用ES 7.10.0自带的JDK在同一台CentOS机器上快速搭建一个多节点测试集群。1. 环境准备与基础配置1.1 系统要求与软件下载首先确保你的CentOS系统满足以下基本要求操作系统CentOS 7.x或更高版本内存至少4GB推荐8GB以上磁盘空间至少10GB可用空间ES 7.10.0版本已经内置了JDK 15这为我们省去了单独安装Java环境的步骤。你可以直接从Elastic官网下载对应版本的ESwget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.10.0-linux-x86_64.tar.gz下载完成后解压文件到指定目录tar -zxvf elasticsearch-7.10.0-linux-x86_64.tar.gz -C /opt/1.2 解决root用户权限问题ES出于安全考虑默认不允许以root用户运行。我们需要创建一个专用用户来运行ES# 创建es用户 useradd es # 设置密码 passwd es # 修改目录权限 chown -R es:es /opt/elasticsearch-7.10.0注意生产环境中强烈建议不要使用root用户运行ES但在测试环境中如果确实需要以root用户运行可以通过添加-Des.insecure.allow.roottrue参数临时解决。2. 单节点启动与验证2.1 启动第一个ES节点切换到es用户并启动第一个ES节点su - es cd /opt/elasticsearch-7.10.0 ./bin/elasticsearch -d启动后可以通过以下命令检查ES是否正常运行curl -X GET localhost:9200/正常响应应该类似这样{ name : your-hostname, cluster_name : elasticsearch, cluster_uuid : xxxxxx, version : { number : 7.10.0, build_flavor : default, build_type : tar, build_hash : xxxxxx, build_date : 2020-11-09T21:30:33.964949Z, build_snapshot : false, lucene_version : 8.7.0, minimum_wire_compatibility_version : 6.8.0, minimum_index_compatibility_version : 6.0.0-beta1 }, tagline : You Know, for Search }2.2 日志检查与问题排查如果启动失败可以查看日志文件排查问题tail -f logs/elasticsearch.log常见问题包括内存不足修改config/jvm.options中的内存设置文件描述符限制修改系统限制ulimit -n 65535虚拟内存限制修改sysctl -w vm.max_map_count2621443. 搭建多节点集群3.1 多节点配置原理在同一台机器上运行多个ES节点需要确保每个节点有独立的数据目录每个节点使用不同的端口所有节点使用相同的集群名称ES提供了命令行参数来动态覆盖配置文件中的设置这让我们无需修改配置文件就能快速启动多个节点。3.2 启动第二个节点在同一个机器上启动第二个节点./bin/elasticsearch -E path.datadata2 -E path.logslog2 \ -E node.namenode2 -E cluster.namemy-test-cluster \ -E http.port9201 -E transport.port9301 -d参数说明path.data指定数据存储目录path.logs指定日志存储目录node.name节点名称cluster.name集群名称必须相同http.portHTTP API端口默认9200transport.port节点间通信端口默认93003.3 验证集群状态通过以下命令检查集群状态curl -X GET localhost:9200/_cluster/health?pretty健康状态应该是green或yellow并且number_of_nodes应该显示为2{ cluster_name : my-test-cluster, status : green, timed_out : false, number_of_nodes : 2, number_of_data_nodes : 2, active_primary_shards : 0, active_shards : 0, relocating_shards : 0, initializing_shards : 0, unassigned_shards : 0, delayed_unassigned_shards : 0, number_of_pending_tasks : 0, number_of_in_flight_fetch : 0, task_max_waiting_in_queue_millis : 0, active_shards_percent_as_number : 100.0 }4. 集群管理与监控4.1 使用Kibana管理集群为了更方便地管理集群我们可以安装Kibanawget https://artifacts.elastic.co/downloads/kibana/kibana-7.10.0-linux-x86_64.tar.gz tar -zxvf kibana-7.10.0-linux-x86_64.tar.gz -C /opt/ cd /opt/kibana-7.10.0-linux-x86_64修改Kibana配置连接我们的集群# config/kibana.yml server.host: 0.0.0.0 elasticsearch.hosts: [http://localhost:9200, http://localhost:9201]启动Kibana./bin/kibana访问http://your-server-ip:5601即可使用Kibana的Dev Tools和Monitoring功能。4.2 节点角色分配在生产环境中我们通常会为节点分配特定角色主节点、数据节点等。在测试环境中可以通过以下参数快速设置# 启动一个专用主节点 ./bin/elasticsearch -E node.namemaster-node -E node.mastertrue -E node.datafalse -d # 启动一个专用数据节点 ./bin/elasticsearch -E node.namedata-node -E node.masterfalse -E node.datatrue -d4.3 集群扩展与缩容要添加更多节点只需重复启动命令并确保使用不同的节点名称使用不同的端口相同的集群名称要移除节点可以直接停止该节点的进程集群会自动重新平衡。5. 高级配置与优化5.1 JVM调优虽然ES自带JVM配置但在多节点环境下可能需要调整# 修改config/jvm.options -Xms1g -Xmx1g提示建议将堆内存设置为不超过物理内存的50%且不超过32GB。5.2 网络配置优化对于本地测试集群可以优化发现机制./bin/elasticsearch -E discovery.seed_hostslocalhost:9300,localhost:9301 -d5.3 索引与分片设置在多节点环境下可以测试不同的分片策略curl -X PUT localhost:9200/my-index -H Content-Type: application/json -d { settings: { number_of_shards: 3, number_of_replicas: 1 } } 6. 常见问题与解决方案在实际搭建过程中可能会遇到以下问题节点无法加入集群检查集群名称是否一致检查防火墙设置验证discovery.seed_hosts配置分片未分配检查集群健康状态确保有足够的数据节点手动分配分片POST /_cluster/reroute性能问题调整JVM堆大小优化索引设置考虑使用SSD存储内存不足减少每个节点的堆内存增加系统交换空间限制字段数据缓存通过本文的实践你应该已经掌握了在同一台机器上快速搭建ES多节点测试集群的方法。这种配置虽然不适合生产环境但对于本地开发测试、学习ES集群工作原理非常有帮助。

相关文章:

从单机到集群:手把手教你用ES 7.10.0自带JDK搭建多节点测试环境

从单机到集群:手把手教你用ES 7.10.0自带JDK搭建多节点测试环境 在当今数据驱动的时代,Elasticsearch(ES)作为一款开源的分布式搜索和分析引擎,已经成为许多企业和开发者处理海量数据的首选工具。对于开发者和测试人员…...

从模型到落地:音频降噪技术选型与工程化实战指南

1. 音频降噪技术选型的核心挑战 当你第一次把降噪模型部署到手机端时,大概率会遇到这样的场景:实验室里效果惊艳的模型,在实际设备上要么卡成幻灯片,要么耗电像开了暖手宝。这就是端侧音频降噪最现实的困境——我们必须在效果、算…...

Python自动化:调用企业微信API高效推送邮件通知

1. 为什么需要企业微信邮件自动化 每天手动发送运营报告的日子我受够了。作为团队的技术负责人,曾经每周都要花2小时整理数据、写邮件、检查收件人列表。直到发现企业微信API能实现全自动化,现在整个过程只需30秒,准确率还更高。 企业微信的邮…...

G-Helper华硕笔记本优化指南:三步告别臃肿控制中心,性能提升30%

G-Helper华硕笔记本优化指南:三步告别臃肿控制中心,性能提升30% 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, …...

【C++笔记】STL详解: stack 和 queue 的使用

前言:在 C 的标准模板库 (STL) 中,stack(栈)和 queue(队列)是非常重要且常用的数据结构。它们都属于“容器适配器”,这意味着它们不是从零开始构建的,而是封装了其他底层容器&#x…...

别再乱改组策略了!深入理解CredSSP更新与远程桌面安全的正确配置姿势

深入解析CredSSP安全机制与远程桌面连接的最佳实践 1. CredSSP协议与加密Oracle漏洞的本质 CredSSP(Credential Security Support Provider)协议是微软开发的一种身份验证协议,主要用于远程桌面连接等场景下的凭据安全传输。2018年曝光的CVE-…...

如何快速下载网页视频:猫抓(cat-catch)浏览器扩展完全指南

如何快速下载网页视频:猫抓(cat-catch)浏览器扩展完全指南 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓(cat-catch)是一款功能强…...

[嵌入式系统]的[WiFi网络配置]:从[连接不稳定]到[可靠通信]的实践指南

[嵌入式系统]的[WiFi网络配置]:从[连接不稳定]到[可靠通信]的实践指南 【免费下载链接】arduino-esp32 Arduino core for the ESP32 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 1. 问题发现:WiFi连接的隐形障碍 当我们在开…...

C#开发者必看:INIFileParser库解决INI配置文件乱码问题的实战指南

C#开发者必看:INIFileParser库解决INI配置文件乱码问题的实战指南 在Windows应用开发中,INI文件作为一种轻量级配置存储格式,至今仍被广泛使用。但许多C#开发者发现,当配置文件路径包含中文、空格或特殊字符时,传统的W…...

计算机毕设源码到底包含什么?一文搞懂标准交付物结构

一、为什么你的毕设源码总被导师打回? 每年毕业季,无数计算机专业学生都会遇到这样的场景:“导师看了一眼你的毕设源码,眉头一皱:‘这交付的什么?数据库脚本呢?接口文档呢?怎么连部署…...

Qwen3.5-9B Visio图表智能生成:根据文本描述自动创建流程图与架构图

Qwen3.5-9B Visio图表智能生成:根据文本描述自动创建流程图与架构图 1. 引言:告别手动绘图的烦恼 你有没有遇到过这样的情况?开会讨论完一个业务流程,需要把它画成流程图;或者设计了一个系统架构,得在Vis…...

避坑指南:RAG Pipeline中多阶段处理的5个性能陷阱与优化方案(附Qwen-Turbo限流配置)

RAG Pipeline性能优化实战:五大关键陷阱与云服务适配方案 当你的RAG系统从Demo走向生产环境时,PDF解析突然内存溢出,向量数据库写入耗时呈指数增长,API调用频繁触发限流——这些性能陷阱往往在真实业务压力下才会暴露。本文将解剖…...

【Python并发成本控制终极指南】:GIL移除后3大无锁模型选型公式与ROI量化对比表

第一章:Python无锁GIL环境下的并发成本控制全景图Python 的全局解释器锁(GIL)长期被视为多线程 CPU 密集型任务的性能瓶颈。然而,随着 CPython 3.13 引入实验性无锁 GIL(--without-pymalloc 配合 --with-experimental-…...

单片机自动脱模剂喷雾控制系统

/***实现功能:检测报警信号,脱模剂开模数计数信号***/ /***参数:1:脱模剂开模数 2:喷雾时间 3:延时时间 ***/ /***串口接收触摸屏参数设置字符串,接收并保存******/ /***端子输入口读开模数,比较设定值后输出到电磁阀**/ /***端子输入口读报警信号,到设定值关闭电机及加热**/#i…...

避坑指南:用Docker部署Oracle 11g时你一定会遇到的5个权限问题(附终极解决方案)

避坑指南:用Docker部署Oracle 11g时你一定会遇到的5个权限问题(附终极解决方案) 在容器化技术席卷全球的今天,Docker已成为部署数据库的首选工具之一。然而,当我们将Oracle 11g这样的传统数据库巨人塞进轻量级容器时&a…...

Java SpringBoot+Vue3+MyBatis 信息化在线教学平台系统源码|前后端分离+MySQL数据库

摘要 随着信息技术的快速发展,教育行业正逐步向数字化、智能化转型。传统的线下教学模式受限于时间和空间,难以满足现代教育的高效性和灵活性需求。在线教学平台通过整合互联网技术与教育资源,为师生提供了便捷的交互渠道,有效提升…...

信号处理避坑指南:一维小波去噪中那些容易忽略的细节

信号处理避坑指南:一维小波去噪中那些容易忽略的细节 在信号处理领域,小波去噪因其优异的时频局部化特性,成为处理非平稳信号的首选方法。然而,许多工程师在应用PyWavelets等工具库时,往往陷入"调参陷阱"——…...

AI的恶意使用

AI 生成的内容与犯罪活动:人工智能系统正被滥用于生成诈骗、欺诈、敲诈勒索及未经同意的私密影像。尽管此类伤害的发生已有充分记录,但关于其发生率和严重程度的系统性数据仍然有限。 影响和操纵:在实验环境中,AI 生成的内容在改变…...

解锁3DS个性化定制:Anemone3DS主题管理器完全指南

解锁3DS个性化定制:Anemone3DS主题管理器完全指南 【免费下载链接】Anemone3DS A theme and boot splash manager for the Nintendo 3DS console 项目地址: https://gitcode.com/gh_mirrors/an/Anemone3DS 3DS主题定制是提升掌机使用体验的关键方式&#xff…...

Nanbeige 4.1-3B Streamlit WebUI效果展示:气泡时间戳与消息状态可视化

Nanbeige 4.1-3B Streamlit WebUI效果展示:气泡时间戳与消息状态可视化 1. 引言:当大模型遇见沉浸式聊天界面 想象一下,你正在本地部署一个强大的开源大语言模型,比如南北阁的4.1-3B版本。你通过命令行与它对话,看着…...

从相位差到厘米级精度:深入解析蓝牙6.0 CS中PBR公式的推导与验证

1. 蓝牙6.0 CS技术中的相位测距原理 蓝牙6.0引入的信道探测(CS)功能将定位精度提升到了厘米级,这主要得益于其采用的相位测距法(PBR)。想象一下,这就像用无线电波玩"激光测距",只不过我们用的是相位差而不是光脉冲。在实际操作中&a…...

5步打造Xbox 360游戏PC运行环境:Xenia Canary模拟器全攻略

5步打造Xbox 360游戏PC运行环境:Xenia Canary模拟器全攻略 【免费下载链接】xenia-canary Xbox 360 Emulator Research Project 项目地址: https://gitcode.com/gh_mirrors/xe/xenia-canary Xenia Canary作为领先的Xbox 360开源模拟器,通过精准的…...

手把手教你用Stable Diffusion v1.5:从安装到生成第一张AI图片

手把手教你用Stable Diffusion v1.5:从安装到生成第一张AI图片 1. 引言 你是否曾经想过,只需输入一段文字描述,就能让AI自动生成一张精美的图片?Stable Diffusion v1.5作为AI图像生成领域的经典模型,让这个梦想变成了…...

如何用RAKE-NLTK实现高效关键词提取:企业级文本分析解决方案

如何用RAKE-NLTK实现高效关键词提取:企业级文本分析解决方案 【免费下载链接】rake-nltk Python implementation of the Rapid Automatic Keyword Extraction algorithm using NLTK. 项目地址: https://gitcode.com/gh_mirrors/ra/rake-nltk 在信息爆炸的数字…...

Blender UV Squares终极指南:3分钟掌握UV网格重塑神器

Blender UV Squares终极指南:3分钟掌握UV网格重塑神器 【免费下载链接】UvSquares Blender addon for reshaping UV quad selection into a grid. 项目地址: https://gitcode.com/gh_mirrors/uv/UvSquares 在3D建模和纹理贴图的世界里,UV Squares…...

2026应届生面试避坑指南:避开这些致命细节,求职成功率翻倍

文章目录前言一、简历不是自传,而是广告文案第一个大坑:把简历做成PPT艺术展。第二个大坑:把简历写成流水账。第三个大坑:一份简历海投百家。二、八股文背得溜,场景题一到就露馅丢分细节一:只会背概念&…...

【新能源功率预测】别再只盯准确率了,2026真正决定收益的,是“预测+交易+储能”一体化

关键词: 新能源功率预测、电力现货交易、储能套利、AI大模型、容量电价 2026年的春天,对于新能源电站的投资人和运营者来说,可谓是“冰火两重天”。 “火”的是政策红利终于实质性落地。【发改价格】114号文将独立储能纳入容量电价体系&…...

终极指南:如何用dlssg-to-fsr3让老款RTX显卡享受帧生成技术

终极指南:如何用dlssg-to-fsr3让老款RTX显卡享受帧生成技术 【免费下载链接】dlssg-to-fsr3 Adds AMD FSR 3 Frame Generation to games by replacing Nvidia DLSS Frame Generation (nvngx_dlssg). 项目地址: https://gitcode.com/gh_mirrors/dl/dlssg-to-fsr3 …...

如何永久保存你的QQ空间记忆:GetQzonehistory完整备份指南

如何永久保存你的QQ空间记忆:GetQzonehistory完整备份指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾经担心过,那些记录着青春岁月的QQ空间说说会随…...

FramePack完整指南:5个关键技巧解决AI视频生成难题

FramePack完整指南:5个关键技巧解决AI视频生成难题 【免费下载链接】FramePack Lets make video diffusion practical! 项目地址: https://gitcode.com/gh_mirrors/fr/FramePack 你是否曾为AI视频生成中的内存溢出、生成速度缓慢和画面漂移问题而烦恼&#x…...