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

目录

概述

准备工作

滚动重启步骤

[1. 禁用分片分配(可选)](#1. 禁用分片分配(可选))

[2. 关闭索引写操作](#2. 关闭索引写操作)

[3. 检查集群状态](#3. 检查集群状态)

[4. 重启Master节点](#4. 重启Master节点)

[5. 重启Data节点](#5. 重启Data节点)

[6. 重新开启索引写操作](#6. 重新开启索引写操作)

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

[8. 监控集群状态](#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参数并进行滚动重启。请确保在操作过程中谨慎行事,并持续监控集群状态,以确保集群的稳定性和性能。

相关推荐
一叶飘零_sweeeet19 小时前
Linux 安装 Elasticsearch:避坑指南 + 性能调优实战
linux·运维·elasticsearch
Han.miracle19 小时前
Java的多线程——多线程(3)线程安全
java·开发语言·jvm·学习·安全·线程·多线程
勇往直前plus21 小时前
centos7利docker compose 快速部署 Elasticsearch + Kibana
elasticsearch·docker·jenkins
Elastic 中国社区官方博客1 天前
通过混合搜索重排序提升多语言嵌入模型的相关性
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
liliangcsdn1 天前
如何使用elasticdump进行elasticsearch数据还原
大数据·elasticsearch·搜索引擎
1.01^10001 天前
[5-01-01].第04节:初识字节码文件 - 字节码文件作用
jvm
lijun_xiao20092 天前
elasticsearch学习笔记-02
笔记·学习·elasticsearch
找不到、了2 天前
JVM核心知识整理《1》
jvm
L.EscaRC2 天前
面向 Spring Boot 的 JVM 深度解析
jvm·spring boot·后端
Elasticsearch2 天前
Elasticsearch:相关性在 AI 代理上下文工程中的影响
elasticsearch