ElasticSearch 出现 cluster_block_exception read_only_allow_delete问题

问题出现的原因
对一个索引做别名的增加,结果报错,如下所示:

{"type"=>"cluster_block_exception", "reason"=>"blocked by: [FORBIDDEN/12/index read-only / allow delete (api)

这里额外附上别名删除和增加的代码:

// 别名可以删除
PUT /ads_lading_trade_brief_es_02/_settings
{"index.blocks.read_only_allow_delete": null}

// 删除老别名
POST /_aliases
{
     "actions": [
        {"remove": {"index": "ads_lading_trade_brief_es_02", "alias": "ads_lading_trade_brief_es"}}
     ]
 }
 
// 为新索引添加别名
 POST /_aliases
{
  "actions": [
    {
      "add": {
        "index": "ads_lading_trade_brief_es_03",
        "alias": "ads_lading_trade_brief_es"
      }
    }
  ]
}

问题分析
这是由于ElasticSearch节点的数据目录data存储空间不足,导致从master主节点接收同步数据的时候失败,此时ElasticSearch集群为了保护数据,会自动把索引分片index置为只读read-only。

解决方法

  • 1 磁盘扩容,可在配置文件中修改ElasticSearch数据存储目录,重启ElasticSearch
  • 2 放开索引只读设置,在服务器上通过curl工具发起PUT请求
PUT /ads_lading_trade_brief_es_03/_settings
{
  "index": {
    "blocks": {
      "read_only_allow_delete": "false"
    }
  }
}

我使用的是第二种方法。

寄语:分享是一种乐趣,你知道的越多,你知道得越少。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值