【Elasticsearch】配置分片分配到指定节点

配置分片分配到指定节点

参考文章:https://www.elastic.co/guide/en/elasticsearch/reference/current/shard-allocation-filtering.html

两种方式:根据节点属性分配和根据节点名称分配。

测试环境

tar xvf elasticsearch-7.17.25-linux-x86_64.tar.gz;cd elasticsearch-7.17.25
./bin/elasticsearch -Ehttp.port=9201 -Epath.data=/home/es/elasticsearch-7.17.25/data/node1_data -Epath.logs=/home/es/elasticsearch-7.17.25/logs/node1_logs -Ecluster.name=sq -Enode.name=node-1 -d
./bin/elasticsearch -Ehttp.port=9202 -Epath.data=/home/es/elasticsearch-7.17.25/data/node2_data -Epath.logs=/home/es/elasticsearch-7.17.25/logs/node2_logs -Ecluster.name=sq -Enode.name=node-2 -d
./bin/elasticsearch -Ehttp.port=9203 -Epath.data=/home/es/elasticsearch-7.17.25/data/node3_data -Epath.logs=/home/es/elasticsearch-7.17.25/logs/node3_logs -Ecluster.name=sq -Enode.name=node-3 -d

根据节点属性分配索引

1. 配置节点的属性状态

在 Elasticsearch 集群中,节点的属性状态可以用来定义节点的特定功能或用途。例如,我们可以为某个节点设置一个名为 box_type 的属性,并将其值设置为 uyun,表示这个节点属于 uyun 类型。配置文件增加后需要重启节点,以便使新的属性状态生效。具体操作如下:

# 在节点的配置文件中增加属性设置
node.attr.box_type: "uyun"

# 重启节点以应用新的配置
# 重启操作会根据具体的部署环境和配置有所不同,例如可以使用以下命令重启 Elasticsearch 服务:
sudo systemctl restart elasticsearch

2. 配置索引模板

索引模板是 Elasticsearch 中用来定义索引创建时的默认设置的工具。通过配置索引模板,我们可以为符合特定模式的索引指定一系列的设置,例如索引的副本数量、分片数量、分析器设置等。以下是一个配置索引模板的示例:

# 使用 curl 命令向 Elasticsearch 发送 PUT 请求,创建一个名为 "test" 的索引模板
curl -H 'Content-type: application/json' -XPUT 'http://127.0.0.1:9201/_template/test'  -d '{
  "index_patterns": "twitter_*",  # 指定该模板适用于所有以 "twitter_" 开头的索引
  "settings": {
    "index.number_of_replicas": "1",  # 设置索引的副本数量为 1
    "index.routing.allocation.require.box_type": "uyun"  # 要求索引只能分配到 box_type 为 "uyun" 的节点上
  }
}'

3. 生成一个新的 twitter 索引

在配置好索引模板之后,我们可以创建一个新的索引,并观察其分配情况。例如,创建一个名为 twitter_2 的索引:

# 使用 curl 命令向 Elasticsearch 发送 PUT 请求,创建 twitter_2 索引
curl -H 'Content-type: application/json' -XPUT 'http://127.0.0.1:9201/twitter_2'

此时,由于我们之前配置的索引模板,新创建的 twitter_2 索引会自动应用模板中的设置,仅分配到 box_typeuyun 的节点上,而之前的索引不受影响。索引模板是针对后续新建的索引生效的,对已存在的索引不会产生影响.
在这里插入图片描述

根据名称分配索引

除了根据自定义属性分配索引外,我们还可以根据节点的名称来分配索引。以下是一个根据节点名称分配索引的示例:

# 创建一个新的索引模板,名为 "test2"
curl -H 'Content-type: application/json' -XPUT 'http://127.0.0.1:9201/_template/test2'  -d '{
  "index_patterns": "sq_*",  # 适用于所有以 "sq_" 开头的索引
  "settings": {
    "index.number_of_replicas": "1",  # 副本数量为 1
    "index.routing.allocation.require._name": "node-2"  # 要求索引只能分配到名称为 "node-2" 的节点上
  }
}'

# 创建一个名为 "sq_1" 的索引
curl -H 'Content-type: application/json' -XPUT 'http://127.0.0.1:9201/sq_1'

此时,新创建的 sq_1 索引会根据 test2 索引模板的设置,仅分配到名称为 node-2 的节点上,而之前的索引不受影响。同样地,索引模板是针对后续新建的索引生效的,对已存在的索引不会产生影响.
在这里插入图片描述
通过以上步骤,我们可以在 Elasticsearch 集群中灵活地配置节点属性和索引模板,实现对索引的合理分配和管理,从而优化集群的性能和资源利用率。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

1. Doris分布式环境搭建

一. 环境准备 本次测试集群采用3台机器hadoop1、hadoop2、hadoop3, Frontend和Backend部署在同一台机器上,Frontend部署3台组成高可用,Backend部署3个节点,组成3副本存储。 主机IP操作系统FrontendBackendhadoop1192.168.47.128Centos7Foll…

计算机毕业设计Python机器学习农作物健康识别系统 人工智能 图像识别 机器学习 大数据毕业设计 算法

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

gesp(C++四级)(11)洛谷:B4005:[GESP202406 四级] 黑白方块

gesp(C四级)(11)洛谷:B4005:[GESP202406 四级] 黑白方块 题目描述 小杨有一个 n n n 行 m m m 列的网格图,其中每个格子要么是白色,要么是黑色。对于网格图中的一个子矩形,小杨认为它是平衡的…

在Mac上使用 Docker 构建一个 noVNC 环境并运行 MyCobot

本文展示了Mycobot 280 M5 上的 Mycobot 280 M5 moveit2 模拟环境,以及详细介绍了使用 Docker 在 macOS(arm64)上构建 moveit2 环境的步骤。 一、引言 这篇文章主要内容是关于如何在 Ros2 环境中构建在 Mac 上模拟 Mycobot 280 M5 的环境。 …

c语言提供后端,提供页面显示跳转服务

后端代码: #define SERVER_IP_ADDR "0.0.0.0" // 服务器IP地址 #define SERVER_PORT 8080 // 服务器端口号 #define BACKLOG 10 #define BUF_SIZE 8192 #define OK 1 #define ERROR 0#include <stdio.h> #include <stdlib.h> #include <st…

AnaConda下载PyTorch慢的解决办法

使用Conda下载比较慢&#xff0c;改为pip下载 复制下载链接到迅雷下载 激活虚拟环境&#xff0c;安装whl&#xff0c;即可安装成功 pip install D:\openai.wiki\ChatGLM2-6B\torch-2.4.1cu121-cp38-cp38-win_amd64.whl

Sentinel服务保护 + Seata分布式事务

服务保护 【雪崩问题】微服务调用链路中某个服务&#xff0c;引起整个链路中所有微服务都不可用。 【原因】&#xff1a; 微服务相互调用&#xff0c;服务提供者出现故障。服务调用这没有做好异常处理&#xff0c;导致自身故障。调用链中所有服务级联失败&#xff0c;导致整个…

六、Angular 发送请求/ HttpClient 模块

一、应用 HttpClient 模块 angular/common/http 中的 HttpClient 类基于浏览器提供的 XMLHttpRequest 接口。要想使用 HtpClient 模块&#xff0c;就要先导入 Anqular 的 HttpClientModule。大多数 Web 应用程序都会在根模块 AppModule 中导入它。 编辑 src/app/app.module.ts…

CompletableFuture // todo

相比较所有代码都在主线程执行&#xff0c;使用Future的好处&#xff1a;利用服务器多核、并发的优势。 不足&#xff1a; 开启没有返回值的异步线程&#xff1a; 1、runAsync 使用lambda表达式&#xff1a; 开启有返回值的异步线程&#xff1a; 1、supplyAsync 异步任务中的…

css面试常考布局(圣杯布局、双飞翼布局、三栏布局、两栏布局、三角形)

两栏布局 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head> &…

arcgisPro加载天地图(CGCS2000)影像

1、注册天地图账号&#xff1b; 2、申请key&#xff1b; 3、添加WMTS服务器。 这里已经办好了前两步&#xff0c;下面详细介绍最后一步。 添加WMTS服务器。 在天地图网站&#xff0c;找到如下页面&#xff0c; 复制网址&#xff0c;如&#xff1a;http://t0.tianditu.gov.cn…

继承(7)

大家好&#xff0c;今天我们继续来学习一下继承的知识&#xff0c;这方面需要大家勤动脑才能理解&#xff0c;那么我们来看。 1.9 protected关键字 在类和对象章节中&#xff0c;为了实现封装特性,java中引入访向限定符,主要限定:类或者类中成员能否在类外和其他包中被访问. …

ModuleNotFoundError: No module named ‘podm.metrics‘报错等解决方法

ModuleNotFoundError: No module named podm.metrics’报错等解决方法 podm.metrics 在运行时报错&#xff1a; ModuleNotFoundError: No module named ‘podm.metrics’ 安装了podm后还是报错 解决方法&#xff1a; 查看安装位置 查看podm的安装位置&#xff0c;并打开到该…

HDFS异构存储和存储策略

一、HDFS异构存储类型 1.1 冷、热、温、冻数据 通常&#xff0c;公司或者组织总是有相当多的历史数据占用昂贵的存储空间。典型的数据使用模式是新传入的数据被应用程序大量使用&#xff0c;从而该数据被标记为"热"数据。随着时间的推移&#xff0c;存储的数据每周…

sklearn-逻辑回归-制作评分卡

目录 数据集处理 分箱 分多少个箱子合适 分箱要达成什么样的效果 对一个特征进行分箱的步骤 分箱的实现 封装计算 WOE 值和 IV值函数 画IV曲线&#xff0c;判断最佳分箱数量 结论 pd.qcut 执行报错 功能函数封装 判断分箱个数 在银行借贷场景中&#xff0c;评分卡是…

中学综合素质笔记3

第一章职业理念 第三节 教师观 考情提示&#xff1a; 单选题材料分析题 学习要求&#xff1a; 理解、 识记、 运用 &#xff08;一&#xff09;教师职业角色的转变&#xff08;单选材料分析&#xff09; 从教师与学生的关系看——对学生 新课程要求教师应该是学生学习的引…

【Linux】设备驱动中的ioctl详解

在Linux设备驱动开发中&#xff0c;ioctl&#xff08;输入输出控制&#xff09;是一个非常重要的接口&#xff0c;用于用户空间应用程序与内核空间设备驱动之间进行通信。通过ioctl&#xff0c;应用程序可以发送命令给设备驱动&#xff0c;控制设备的行为或获取设备的状态信息。…

linux上使用cmake编译的方法

一、hello 例程仅基于一个cpp文件 C文件或工程进行编译时可以使用g指令&#xff08;需要对每一个程序和源文件分别使用g指令编译&#xff09;&#xff0c;当程序变大时&#xff0c;一个工程文件往往会包含很文件夹和源文件&#xff0c;这时我们需要的编译指令将越来越长&#…

(vue)el-table-column type=“selection“表格选框怎么根据条件添加禁选

(vue)el-table-column type"selection"表格选框怎么根据条件添加禁选 html <el-table:data"tableData"style"width: 100%"><el-table-columntype"selection"width"55":selectable"checkSelectable">…

linux nginx 安装后,发现SSL模块未安装,如何处理?

&#x1f468;‍⚕ 主页&#xff1a; gis分享者 &#x1f468;‍⚕ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕ 收录于专栏&#xff1a;运维工程师 文章目录 前言SSL模块安装 前言 nginx 安装后&#xff0c;发现SSL模块未安装&…