Elastic Stack-ES集群常用的API

2024-09-06 01:36
文章标签 es 集群 stack api 常用 elastic

本文主要是介绍Elastic Stack-ES集群常用的API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除

学习B站博主教程笔记: 

最新版适合自学的ElasticStack全套视频(Elk零基础入门到精通教程)Linux运维必备—ElasticSearch+Logstash+Kibana精讲_哔哩哔哩_bilibiliicon-default.png?t=O83Ahttps://www.bilibili.com/video/BV1VMW3e6Ezk/?spm_id_from=333.1007.tianma.1-1-1.click&vd_source=e539f90574cdb0bc2bc30a8b5cb3fc00

1、ES集群健康状态API

 # 安装jq工具yum -y install epel-releaseyum -y install jq​# 测试取数据[root@k8s-master ~]# curl http://192.168.1.10:9200/_cluster/health 2>/dev/null | jq{"cluster_name": "cluster-elk","status": "green","timed_out": false,"number_of_nodes": 3,"number_of_data_nodes": 3,"active_primary_shards": 25,"active_shards": 42,"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}​[root@k8s-master ~]# curl http://192.168.1.10:9200/_cluster/health 2>/dev/null | jq .status"green"
 GET http://192.168.1.10:9200/_cluster/health相关参数说明:cluster_name:集群的名称status:集群的健康状态,基于其主分片和副本分片的状态ES集群有以下三种状态:green:所有分片都已分配yellow:所有主分片都已分配,但一个或多个副本未分配;如果集群中的某个节点发生故障,则在修复该节点之前,某些数据可能不可用red:一个或多个主分片未分配,因此某些数据不可用,可能会在集群启动期间短暂发生,因为分片了主分片timed_out: 是否有超时;默认30秒number_of_nodes: 集群内的节点数active_primary_shards: 可用主分片数量active_shards: 可用主分片与副本分片的总数relocating_shards: 正在重定位的分片数initializing_shards: 正在初始化的分片数unassigned_shards: 未分配的分片数delayed_unassigned_shards: 分配因超时设置而延迟的分片数number_of_pending_tasks: 尚未执行的集群级别更改的数量number_of_in_flight_fetch: 未完成的提取次数task_max_waiting_in_queue_millis: 自最早启动的任务等待执行以来的时间active_shards_percent_as_number: 集群中活动分片

2、ES集群的设置及优先级

如果使用多种方法配置相同的设置,Elasticsearch会按以下优先顺序应用这些设置:

  • Transient setting(临时设置,集群重启后失效)
  • Persistent setting(持久化配置,集群重启后依旧生效)
  • elasticsearch.yml setting(配置文件)
  • Default setting value(默认设置值)
 # 查询集群的所有配置信息http://192.168.1.10:9200/_cluster/settings?include_defaults=true&flat_settings=true​# 修改集群的配置信息PUT http://192.168.1.10:9200/_cluster/settings{"transient":{"cluster.routing.allocation.enable":"none"}}​# 相关参数说明"cluster.routing.allocation.enable":"all": 允许所有分片类型进行分配"primaries": 仅允许分配主分片"new_primaries": 仅允许新创建索引分配主分片"none":不允许分配任何类型的分片

3、集群状态API

集群状态是一种内部数据结构,它跟踪每个节点所需的各种信息,包括:

  • 集群中其他节点的身份和属性
  • 集群范围的设置
  • 索引元数据,包括每个索引的映射的设置
  • 集群中每个分片副本的位置和状态
 # 查看集群的状态信息GET http://192.168.1.10:9200/_cluster/state​# 只查看节点信息GET http://192.168.1.10:9200/_clusrer/state/nodes​# 查看nodes,version,routing_table这些信息,并且查看以"cluester*"开头的所有索引GET http://192.168.1.10:9200/_cluster/state/nodes,version,routing_table/cluster*

4、集群统计API

Cluster State API允许从集群范围的角度检索统计信息。返回基本的索引指标(分片数量,存储大小,内存使用情况)和有关构成集群的当前节点的信息(数量,角色,操作系统,JVM版本,内存使用情况,cpu和已安装的插件)

 # 查看统计信息GET http://192.168.1.10:9200/_cluster/stats

5、查看集群的分片分配情况

集群分配解释API的目的是为集群中的分片分配提供解释

对于未分配的分片,解释API提供了有关未分配分片的原因和解释;对于已分配的分片,解释API解释了为什么分片保留在其他节点上并且没有移动或重新平衡到另一个节点。

 # 分析teacher索引的0号分片未分配的原因GET http://192.168.1.10:9200/_cluster/allocation/explain{"index": "teacher","shard": 0"primary": true}

6、集群分片重路由API

reroute命令允许手动更改集群中各个分片的分配

 # 将"teacher"索引的0号分片从master节点移动到node1节点POST http://192.168.1.10:9200/_cluster/reroute{"commands":{"move":{"index": "teacher","shard": 0,"from_node": "master","to_node": "node1"}}}​# 取消副本分片的分配,其副本会重新初始化分配POST http://192.168.1.10:9200/_cluster/reroute{"commands":{"move":{"index": "teacher","shard": 0,"node": "node1"}}}

致谢

在此,我要对所有为知识共享做出贡献的个人和机构表示最深切的感谢。同时也感谢每一位花时间阅读这篇文章的读者,如果文章中有任何错误,欢迎留言指正。 

学习永无止境,让我们共同进步!!

这篇关于Elastic Stack-ES集群常用的API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140630

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现