单节点Elasticsearch出现unassigned_shards原因及解决办法

单节点Elasticsearch副本分片问题
在单节点Elasticsearch集群中,由于无法分配副本分片导致集群状态为yellow。本文解释了副本分片的作用及在单节点环境下存在的问题,并提供了将副本数设置为0的解决方案。

https://blog.youkuaiyun.com/x4609883/article/details/79926267

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.youkuaiyun.com/x4609883/article/details/79926267

查看单节点Elasticsearch健康状态

使用head插件查看集群状态

从上面截图可以看出存在5个unassigned的分片,新建索引blog5的时候,分片数为5,副本数为1,新建之后集群状态成为yellow,其根本原因是因为集群存在没有启用的副本分片,我们先来看一下官网给出的副本分片的介绍:

副本分片的主要目的就是为了故障转移,正如在 集群内的原理 中讨论的:如果持有主分片的节点挂掉了,一个副本分片就会晋升为主分片的角色。

那么可以看出来副本分片和主分片是不能放到一个节点上面的,可是在只有一个节点的集群里,副本分片没有办法分配到其他的节点上,所以出现所有副本分片都unassigned得情况。因为只有一个节点,如果存在主分片节点挂掉了,那么整个集群理应就挂掉了,不存在副本分片升为主分片的情况。

解决办法就是,在单节点的elasticsearch集群,删除存在副本分片的索引,新建索引的副本都设为0。然后再查看集群状态

新建索引副本数设置为0

转载于:https://my.oschina.net/iioschina/blog/1998012

[root@k8s-master01 elasticsearch]# kubectl exec -it -n logging elasticsearch-master-0 -- curl -k -u elastic:123qqq...A https://localhost:9200/_cluster/health?pretty Defaulted container "elasticsearch" out of: elasticsearch, configure-sysctl (init) { "cluster_name" : "elasticsearch", "status" : "green", "timed_out" : false, "number_of_nodes" : 1, "number_of_data_nodes" : 1, "active_primary_shards" : 1, "active_shards" : 1, "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.0 } [root@k8s-master01 elasticsearch]# kubectl exec -it -n logging elasticsearch-master-1 -- curl -k -u elastic:123qqq...A https://localhost:9200/_cluster/health?pretty Defaulted container "elasticsearch" out of: elasticsearch, configure-sysctl (init) { "cluster_name" : "elasticsearch", "status" : "green", "timed_out" : false, "number_of_nodes" : 2, "number_of_data_nodes" : 2, "active_primary_shards" : 1, "active_shards" : 2, "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.0 } [root@k8s-master01 elasticsearch]# kubectl exec -it -n logging elasticsearch-master-2 -- curl -k -u elastic:123qqq...A https://localhost:9200/_cluster/health?pretty Defaulted container "elasticsearch" out of: elasticsearch, configure-sysctl (init) { "cluster_name" : "elasticsearch", "status" : "green", "timed_out" : false, "number_of_nodes" : 2, "number_of_data_nodes" : 2, "active_primary_shards" : 1, "active_shards" : 2, "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.0 }
最新发布
04-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值