Elasticsearch集群异常状态 yellow 问题处理_es状态yellow怎么办

“task_max_waiting_in_queue_millis” : 0,
“active_shards_percent_as_number” : 90.0 (集群中活动碎片的比率,以百分比表示)
}

以 json 的方式显示集群具体的异常信息

curl -XGET http://192.168.1.20:9200/_cluster/allocation/explain |python3 -m json.tool

报错显示 “allocate_explanation”: “cannot allocate because allocation is not permitted to any of the nodes”

在这里插入图片描述

当集群状态异常时,同时需要重点关注unassigned_shards没有正常分配的分片,查看集群状态可知存在一个未分配的分片数

查看索引情况,并根据返回找到状态异常的索引

curl -XGET http://192.168.1.20:9200/_cat/indices

在这里插入图片描述

查看索引设置

curl -XGET http://192.168.1.20:9200/flog-2024.03.20/_settings

关注 “number_of_replicas” : “1” 代表此处的副本分片的大小。此处假设 number_of_replicas的数量为1,则说明1个分片未分配

在这里插入图片描述

当副本数大于或等于数据节点数时,那么每个分片只能最多有 节点数量-1个副本,无法分配的副本数则为 主分片数x(副本数-(节点数-1))

例如:假设节点数为3,主分片数为5,副本数为3,那么无法分配的副本数则为:5*(3-(3-1))=5。

本环境的ES是单节点测试环境,则副本分片应为0,而yellow状态异常索引settings中,副本分片大小为1,因此此时只需要重新设置该索引副本分片数即可

[root@test ~]# curl -X PUT -H “Content-Type: application/json” -d ‘{“number_of_replicas”:“0”}’ ‘http://192.168.1.20:9200/flog-2024.03.20/_settings’
{“acknowledged”:true}
[root@test ~]#
[root@test ~]#
[root@test ~]# curl -XGET http://192.168.1.20:9200/flog-2024.03.20/_settings |python3 -m json.tool
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 295 100 295 0 0 144k 0 --:–:-- --:–:-- --:–:-- 144k
{
“flog-2024.03.20”: {
“settings”: {
“index”: {
“routing”: {
“allocation”: {
“include”: {
“_tier_preference”: “data_content”
}
}
},
“number_of_shards”: “1”,
“provided_name”: “flog-2024.03.20”,
“creation_date”: “1710903076855”,
“number_of_replicas”: “0”,
“uuid”: “J-0ggL-uQWOVHjliT9e-lA”,
“version”: {
“created”: “7171099”
}
}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数大数据工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
img

,并且后续会持续更新**

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
[外链图片转存中…(img-qZsZUqq8-1712516643444)]

  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Elasticsearch 集群状态yellow 时,表示所有的主分片都已经分配到了某些节点上,但是某些副本分片尚未分配到节点上。这种情况下,Elasticsearch 集群仍然可以工作,但是如果任何一个节点失败,那么可能会导致数据丢失或不可用。 要解决这个问题,您可以考虑以下几个步骤: 1. 扩大集群规模:如果您的集群规模较小,则可以尝试增加节点数以获得更多的分片和副本分片。这样可以使分片和副本分片更容易在节点之间分配。 2. 提高硬件配置:如果您的节点硬件配置较低,则可以考虑升级硬件配置以提高节点性能。 3. 调整分片数量:您可以尝试调整分片数量以更好地适应您的数据和节点。例如,如果您的数据非常小,那么您可以考虑减少分片数量。 4. 重新分配副本分片:您可以手动重新分配副本分片以确保每个节点都有足够的副本分片。您可以使用 Elasticsearch 的 API 来执行此操作。例如,您可以使用 _cat/shards API 来查看分片和节点分配情况,然后使用 _cluster/reroute API 来重新分配副本分片。 5. 检查节点状态:您可以检查节点的状态以确保它们正常运行并且可以与其他节点通信。您可以使用 Elasticsearch 的 API 来查看节点状态。例如,您可以使用 _cat/nodes API 来查看节点列表和状态。 总之,解决 Elasticsearch 集群状态yellow问题需要您根据实际情况采取适当的措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值