【ES实战】ES集群节点迁移与缩容

news2025/1/11 19:55:06

ES集群节点迁移与缩容

文章目录

    • ES集群节点迁移与缩容
    • master节点迁移
      • 场景一
      • 场景二
      • 场景三
    • data节点迁移
    • 数据迁移操作
        • 1、查询集群原来的配置
        • 2、清空节点数据
        • 3、检查是否排空数据
    • 迁移原则
    • 缩容前置检查项

master节点迁移

场景一

集群上的master部署情况,一台机器上同时部署了纯master角色和纯data角色的两个ES节点

  1. 申请新机器DEF,为新机器申请域名。
  2. 在新机器DEF上各自部署纯data角色的ES节点,将所有节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为ABCDEF。
  3. 将数据迁移到DEF中的数据ES节点中。同时客户端修改链接地址为DEF。
  4. 数据迁移完毕后,关闭一个非active master的ES节点,在DEF中选择一个启动纯master角色的ES节点。
  5. 重复步骤4,直到只剩下非active master的ES节点未调整。
  6. 关闭active master的ES节点,启动新机器中的纯master角色的ES节点,新的active master会在DEF中选举产生。
  7. 确认用户客户端链接地址修改完毕后,下线ABC机器。将DEF中ES全部节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为DEF。
    在这里插入图片描述

场景二

集群上的master部署情况,机器上的master角色是与data角色混在一个ES节点中

  1. 申请新机器DEF,为新机器申请域名。
  2. 在新机器DEF上各自部署纯data角色的ES节点,将所有节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为ABCDEF。
  3. 将数据迁移到DEF中的数据ES节点中。同时客户端修改链接地址为DEF。
  4. 数据迁移完毕后,关闭一个非active master的ES节点,在DEF中选择一个启动纯master角色的ES节点。
  5. 重复步骤4,直到只剩下非active master的ES节点未调整。
  6. 关闭active master的ES节点,启动新机器中的纯master角色的ES节点,新的active master会在DEF中选举产生。
  7. 确认用户客户端链接地址修改完毕后,下线ABC机器。将DEF中ES全部节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为DEF。
    在这里插入图片描述

场景三

集群上的master部署情况,纯master角色ES节点和纯Data角色ES节点部署在不同的服务器上

  1. 申请新机器GHIJ,为新机器申请域名。
  2. 在新机器GHIJ上各自部署纯data角色的ES节点,将所有节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为DEFGHI。
  3. 将数据迁移到GHIJ中的dataES节点中。同时客户端修改链接地址为GHIJ。
  4. 数据迁移完毕后,关闭一个非active master的ES节点,在GHI中选择一个启动纯master角色的ES节点。
  5. 重复步骤4,直到只剩下非active master的ES节点未调整。
  6. 关闭active master的ES节点,启动新机器中的纯master角色的ES节点,新的active master会在GHI中选举产生。
  7. 确认用户客户端链接地址修改完毕后,下线ABCM机器。将GHIJ中ES全部节点的配置文件elasticsearch.yml中的配置项discovery.zen.ping.unicast.hosts修改为GHI。
    在这里插入图片描述

data节点迁移

  1. 申请新机器,为新机器申请域名。
  2. 在新机器各自部署纯data角色的ES节点。
  3. 检查是否需要更改ES客户端的链接地址。
  4. 将需要迁移data节点的所有索引数据迁移到新机器。
  5. 下线需要迁移的机器。

数据迁移操作

主要使用配置项cluster.routing.allocation.exclude._ip来实现数据迁移。

1、查询集群原来的配置

检查cluster.routing.allocation.exclude._ip配置项的值,如果没有,说明原来没有排除节点。

curl -X GET "http://{ip}:{port}/_cluster/settings?pretty"

2、清空节点数据

清空数据节点的数据,{ip}:集群任意节点IP,{port}:http服务端口号,{ip1},{ip2}:需要排除数据的IP,将原来配置需要排除数据的节点IP加上本次排除数据的节点IP,以逗号分隔。

curl -X PUT "http://{ip}:{port}/_cluster/settings?pretty" -H 'Content-Type: application/json' -d'
{
  "persistent" :{
      "cluster.routing.allocation.exclude._ip" : "{ip1},{ip2}"
   }
}'

3、检查是否排空数据

检查数据节点上是否存在数据,结果中的IP列没有需要下线的IP,说明数据已经排尽,满足机器下线条件了。有的集群分片可能很多,可以将结果输出到文件查询。

curl -X GET "http://{ip}:{port}/_cat/shards?v&pretty&s=ip:desc"
index               shard prirep state   docs  store ip            node
config_s-20211108 1     r      STARTED    0   130b 192.168.1.1 es03-prd
config_s-20211108 2     r      STARTED    0   130b 192.168.1.1 es03-prd
config_s-20211108 0     p      STARTED    0   130b 192.168.1.1 es03-prd
.monitoring-data-2  0     r      STARTED    5 15.7kb 192.168.1.1 es03-prd
config_s-20211107 1     r      STARTED    0   130b 192.168.1.1 es03-prd
config_s-20211107 2     r      STARTED    0   130b 192.168.1.1 es03-prd
config_s-20211107 0     p      STARTED    0   130b 192.168.1.1 es03-prd

迁移原则

  • 清理集群中的过期索引与过期数据
  • 优先扩容data角色的节点,迁移集群中的数据
  • 确认客户端的链接地址不是要下线的机器
  • 迁移非active的master角色的节点
  • 切主,将active的master节点进行关闭,在新master角色的节点中完成新的active master选主。
  • 刷新集群上的相关配置
  • 在确认所有事项之后,才能下线旧机器

缩容前置检查项

  1. index的副本分片数量的合理性

    副本数 + 1 ≤ +1\leq +1data角色的节点数

  2. 单个ES数据节点的分片数量的合理性

    官方的默认值是每个数据节点的分片数 ≤ \leq 1000,

    https://www.elastic.co/guide/en/elasticsearch/reference/6.7/misc-cluster.html#cluster-shard-limit

  3. 大分片的数量
    在这里插入图片描述

  4. 数据生命周期的调整

  5. 单机器多数据节点的 cluster.routing.allocation.same_shard.host 配置的调整,最佳为true。

    允许执行检查,以防止基于主机名和主机地址在单个主机上分配同一分片的多个实例。 默认为false,表示默认情况下不执行任何检查。 仅当在同一台计算机上启动多个节点时,此设置才适用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/129776.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智能化IT运维平台建设方案,基于智和信通运维体系的高敏捷二次开发

随着企业信息进程不断加速,运维人员需要面对越来越复杂的业务和越来越多样化的用户需求,不断扩展的应用需要越来越合理的模式、越来越智能的工具来保障运维能灵活便捷、安全稳定地开展。企业网络规模的不断扩大,从初期的几台服务器发展到庞大…

Python3 | vscode配置环境

vscode版本:1.74.2python版本:3.9.0win10系统 准备工作,在win10系统 1,安装python3,配置环境变量2,安装vscode 接下来:就可以在vscode配置python环境 1,下载和安装python插件 快…

2022年总结以及2023年的计划

2022年总结以及2023年的计划 文章目录2022年总结以及2023年的计划年终复盘投资理财学习方面前端方面:后端方面:数据库:读书:疫情工作爱情新的一年的展望按照每年的惯例,我每年的总结,复盘会在这几天完成。 …

软件测试精准定位BUG小技巧

目录 一、前置知识 二、定位技巧 一、前置知识 1. 熟透系统业务、团队成员情况 2. 熟悉使用F12或抓包工具 3. 了解HTTP/HTTPS协议,能够区分请求URL、请求头、请求体、入参、响应数据、响应码 4. 具备操作常规Linux命令,能否登入服务器查看Log日志&…

通信原理 | 波段的划分

波段(wave band) 在无线电技术中,波段(wave band)这个名词具有两种含义。 电磁波频谱的划分,例如长波、短波、超短波等波段。 发射机、接收机等设备的工作频率范围的划分。若把工作频率范围分成几个部分,这些部分也称为波段,例如三波段收音机等。 波段划分 波段通常是…

Python实现A股股市情感分析,含数据集可直接运行

Python实现A股股市情感分析,含数据集可直接运行 Stock Market Sentiment Analysis: 股市情感分析 完整代码下载地址:Python实现A股股市情感分析 情绪与股市 情绪与股市关系的研究由来已久,情绪是市场的一个重要影响因素已成为共识。 15年…

【设计模式】状态模式

状态模式 状态机 在操作系统的调度中会存在三种状态:运行、就绪、阻塞。 这是比较典型的状态机的例子。 做产品的时候,我们总能遇到一些比较复杂的逻辑问题,而普通的流程图,或时序图对于对象和状态的解读缺乏直观的描述。 这…

2.16 SPI协议的4种模式

文章目录1、简介2、SPI通讯模式2.1 模式02.2 模式12.3 模式22.4 模式32.5 总述1、简介 四线控制 SDO - 主设备数据输出,从设备输入 对应MOSI SDI - 主设备数据输入,从设备输出 对应MISO SCLK - 时钟信号,由主设备产生 CS - 从设备使能信号&a…

java接口的静态方法

目前java中已经支持定义静态方法 但需要注意一个点 我们先把代码写出来 我们创建一个包 下面创建一个接口 subInterface 接口参考代码如下 public interface subInterface {static void show2() {System.out.println("来自接口的静态方法");} }这里 我们就将 sho…

【C递归和迭代】兔子繁殖问题、青蛙跳台阶问题和汉诺塔问题

【C递归】前言一、兔子繁殖问题(一)题目描述(二)解题1.递归做法(1)成兔(i)分析(ii)代码(iii)代码分析(2)幼兔&…

C语言实现简易版扫雷

扫雷对于很多人是一种回忆,那么我们如何用C语言程序去实现它呢?这个是在浏览器找到的一个扫雷游戏我用程序实现它利用到字符数组,将一个类似棋盘的东西打印出来,让人们输入坐标,然后进行扫雷。为了程序的简易我一共设计…

论文阅读-社交媒体上的谣言检测:数据集、方法和机会

论文链接:https://aclanthology.org/D19-5008.pdf 目录 摘要 引言 1.1谣言检测 1.2 问题陈述 1.3 用户立场 2 数据集和评估指标 2.1 数据集 2.2 评价指标 3 特点和方法 3.1使用内容信息的方法 3.2 利用用户信息的方法 3.3 基于传播路径和网络的方法 3.4…

volatile 禁止指令重排序

计算机在执行程序时,为了提高性能,编译器和处理器常常会对指令重排,一般分为以下三种: 源代码 -> 编译器优化的重排 -> 指令并行的重排 -> 内存系统的重排 -> 最终执行指令单线程环境里面确保最终执行结果和代码顺序的…

AWS人工智能主题学习月:深度学习入门笔记

目录 一、深度学习入门课程的学习重点📕 二、简单介绍一下深度学习和神经网络💡 1.深度学习 2.神经网络 3.深度学习储备知识拓展 三、深度学习生产生活实际案例🚗 四、深度学习的框架介绍🌳 总结 深度学习是机器学习中的一…

Arch/Manjaro安装搜狗输入法

装好系统以后,没有输入法,只能打英文的感觉很难受,现在我们来看看如何给Arch系列的系统安装搜狗输入法。 加入Skype Linux群来这里一起解决问题吧!腾讯不支持Linux,让我们一起抛弃微信~ Join conversationhttps://join…

⌈ 2022杀青 ⌋ 一个普通人的年终总结,这一年我获得了更多的新鲜体验 | 普通而平凡的一年 | 向前走,走到光里 | 2023你好

💛年度总结💛 时间转瞬便是年末,在此写下告别 成长是一场踏实的幻灭 有哭有笑有酸有甜,失去与获得也同在 即使生活再忙,也不要忘记那些美好治愈我们的瞬间 起起伏伏的日子,这依然是很长很好的一年&…

python 爬虫 使用selenium 控制浏览器 进行搜索操作

首先需要安装selenium: 第一种:可以自己下载selenium tar.gz包,下载到python目录下:解压到当前文件夹 在cmd命令行:进入到解压包中,进行安装。安装完成之后,如果是eclipse中,请 clean project之…

APSIM练习3:氮循环

在本练习中,您将观察休耕情况下的氮肥循环;尿素转化为铵,铵转化为硝酸盐,以及土壤硝酸盐通过反硝化作用流失。此模拟将介绍编辑一个简单的管理器规则以及绘制模拟结果的更多高级功能。 开始基于 Continuous Wheat.apsim 的新模拟。…

【20221230】栈和队列的小结

一、栈(stack) 栈是先进后出的(FILO)的数据结构,它只有一个出口。 二、队列 队列是一种先进先出(FIFO)的数据结构,它有两个出口。 栈和队列是STL(C标准库)里面…

【攻防世界】Web easyupload

知识点讲解 本题的主要考点为利用fastcgi的.user.ini特性进行任意命令执行 关于.user.ini文件是怎么利用的,可以点此查看非常详细,我这里截取一段 .user.ini实际上就是一个可以由用户“自定义”的php.ini,我们能够自定义的设置是模式为“PHP…