elasticsearch的unassigned shards的处理(续)

所用elasticsearch版本为1.6.0。


有时候单机上的es会出现unassigned shards的情况,原因不明,但还是可以做数据恢复的。


想要恢复数据分片,主要是关注es存储数据的路径。在1.6.0的版本中,es的数据是存在elasticsearch-1.6.0/data目录下,该目录的子文件即是各个不同es集群的数据,如果开启过多个es服务时,会留下以es集群名称为命名的文件夹。


以默认的elasticsearch文件夹为例,在./elasticsearch/nodes的目录下,根据es设置的副本数会有几个文件夹,副本为0时只有0文件夹,副本为1时有0和1两个文件夹,以此类推。以0目录为例,其子文件夹indices底下即为各个索引的数据,每个索引的目录下显示的是该es中存储的shards,单台理论上是有0、1、2、3、4(默认为5)。当做了分布式有副本时,可以看到每个索引下的0、1、2、3、4可能只有其中1个、2个或3个情况,因为是冗余要求。


当有unassigned shards时,意味着有数据没有进行分配,这时候数据还在data目录下,只是不在其该在位置而已。以es集群做了一个副本为例,nodes下有0和1文件夹存储数据,但有unassigned shards时,某台服务器上会出现2的文件。这个2文件夹里的数据就是unassigned shards的数据,只需要把2目录的对应索引的分片重新拷回0或者1目录下对应的分片应当存在的位置,重启es后,即可发现分片数据恢复。


偶然发现这个方法,过程泣泪两行。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值