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

【DevOps】Elasticsearch集群JVM参数调整及滚动重启指南

目录

概述

准备工作

滚动重启步骤

1. 禁用分片分配(可选)

2. 关闭索引写操作

3. 检查集群状态

4. 重启Master节点

5. 重启Data节点

6. 重新开启索引写操作

7. 启用分片分配(如果之前禁用了)

8. 监控集群状态

结论


概述

本文档旨在提供一个详细的指南,帮助用户在Elasticsearch集群中调整JVM参数并进行滚动重启。滚动重启是一种逐步重启集群节点的方法,旨在最小化对集群性能和可用性的影响。Elasticsearch集群的环境包括3台master节点,三台data节点。下面我们看一下具体实现步骤。

准备工作

  1. 备份配置文件
    在每个节点上备份jvm.options文件。

    cp /etc/elasticsearch/jvm.options /etc/elasticsearch/jvm.options.backup
    
  2. 修改JVM参数
    编辑每个节点的/etc/elasticsearch/jvm.options文件,调整所需的JVM参数。例如,调整堆内存大小:

    -Xms4g
    -Xmx4g
    

滚动重启步骤

1. 禁用分片分配(可选)

在任意一个Master节点上执行以下命令,禁用分片分配:

curl -X PUT "http://localhost:9200/_cluster/settings" -H 'Content-Type: application/json' -d'
{"persistent": {"cluster.routing.allocation.enable": "primaries"}
}'

2. 关闭索引写操作

在任意一个Master节点上执行以下命令,关闭所有索引的写操作:

curl -X PUT "http://localhost:9200/_all/_settings" -H 'Content-Type: application/json' -d'
{"index.blocks.write": true
}'

3. 检查集群状态

确保集群状态为黄色或绿色,等待所有分片被分配:

curl -X GET "http://localhost:9200/_cluster/health?wait_for_status=yellow&timeout=30s"

4. 重启Master节点

依次重启每个Master节点,确保每次重启后集群保持稳定。

  • 重启Master节点1

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Master节点1成功加入集群并状态正常。

  • 重启Master节点2

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Master节点2成功加入集群并状态正常。

  • 重启Master节点3

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Master节点3成功加入集群并状态正常。

5. 重启Data节点

依次重启每个Data节点,确保每次重启后集群保持稳定。

  • 重启Data节点1

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Data节点1成功加入集群并状态正常。

  • 重启Data节点2

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Data节点2成功加入集群并状态正常。

  • 重启Data节点3

    sudo systemctl restart elasticsearch
    
  • 检查节点状态

    curl -X GET "http://localhost:9200/_cat/nodes"
    
  • 等待节点加入集群
    确保Data节点3成功加入集群并状态正常。

6. 重新开启索引写操作

在任意一个Master节点上执行以下命令,重新开启所有索引的写操作:

curl -X PUT "http://localhost:9200/_all/_settings" -H 'Content-Type: application/json' -d'
{"index.blocks.write": false
}'

7. 启用分片分配(如果之前禁用了)

在所有节点重启完成后,重新启用分片分配:

curl -X PUT "http://localhost:9200/_cluster/settings" -H 'Content-Type: application/json' -d'
{"persistent": {"cluster.routing.allocation.enable": "all"}
}'

8. 监控集群状态

在重启完成后,持续监控集群的健康状态和性能指标,确保一切正常。

结论

通过以上步骤,你可以在Elasticsearch集群中安全地调整JVM参数并进行滚动重启。请确保在操作过程中谨慎行事,并持续监控集群状态,以确保集群的稳定性和性能。

http://www.lryc.cn/news/391091.html

相关文章:

  • 软设之多态
  • SD NAND时序解析
  • CSS-实例-div 水平居中 垂直靠上
  • 数据分析入门指南:从基础概念到实际应用(一)
  • ArcGIS Pro三维空间分析、专题制图、遥感制图全流程系统教学
  • Redis 7.x 系列【17】四种持久化策略
  • 开发经验:go切片的继承
  • PyQt5事件机制解析:从原理到实战一网打尽!
  • GraphQL与RESTful API的区别和优势
  • 关于 Qt4Qt5迁移至Qt6出现QDesktopWidget和QApplication::desktop()删除后兼容Qt6 的解决方法
  • 【HarmonyOS NEXT】鸿蒙Socket 连接
  • 1978Springboot在线维修预约服务应用系统idea开发mysql数据库web结构java编程计算机网页源码maven项目
  • 【vue】实现自动轮播+滚轮控制
  • 鸿翼FEX文件安全交换系统,打造安全高效的文件摆渡“绿色通道”
  • 苹果电脑虚拟机运行Windows Mac环境安装Win PD19虚拟机 parallels desktop19虚拟机安装教程免费密钥激活
  • 昇思25天学习打卡营第11天|基于MindSpore通过GPT实现情感分类
  • 【Python】变量与基本数据类型
  • Unity按键表大全
  • 第一周java。2
  • Arduino - Keypad 键盘
  • 国产芯片方案/蓝牙咖啡电子秤方案研发
  • reactjs18 中使用@reduxjs/toolkit同步异步数据的使用
  • 剧本杀小程序:助力商家发展,提高游戏体验
  • pikachu靶场 利用Rce上传一句话木马案例(工具:中国蚁剑)
  • CenterOS7安装java
  • react 重新加载子组件
  • 从零开始使用WordPress搭建个人网站并一键发布公网详细教程
  • 浅谈chrome引擎
  • 【常用知识点-Java】创建文件夹
  • 【JavaScript脚本宇宙】颜色处理神器大比拼:哪款JavaScript库最适合你?