Elasticsearch reindex操作

需求

我有一个index:test_1,这个index由于各种原因,mapping中出现了下面的type:

"u_ori_id_list" : {
              "type" : "text",
              "fields" : {
                "keyword" : {
                  "type" : "keyword",
                  "ignore_above" : 256
                }
              }
            }

我想将u_ori_id_list的类型改为keyword,而且不想丢数据,因此使用Elasticsearch中的reindex来解决。

解决办法

我目前使用的Elasticsearch版本是7.17.7

首先在目标索引test_2,并将u_ori_id_list字段设置为:

"u_ori_id_list" : {
	"type" : "keyword"
}

然后执行下面的语句:

POST _reindex
{
  "source": {
    "index": "test_1"
  },
  "dest": {
    "index": "test_2"
  }
}

由于这一过程可能很长,所以最好不要在kibana中执行,而是使用curl的方式执行。

curl -X POST -H "Content-Type: application/json" http://10.26.120.31:9200/_reindex -d '
{
  "source": {
    "index": "test_1",
    "size": 100
  },
  "dest": {
    "index": "test_2"
  }
}'

并且如果不设置"size":100,那么默认的操作是1000,如果数据量太大则会报错:

{"error":{"root_cause":[{"type":"es_rejected_execution_exception","reason":"rejected execution of coordinating operation [coordinating_and_primary_bytes=0, replica_bytes=0, all_bytes=0, coordinating_operation_bytes=859110825, max_coordinating_and_primary_bytes=858993459]"}],"type":"es_rejected_execution_exception","reason":"rejected execution of coordinating operation [coordinating_and_primary_bytes=0, replica_bytes=0, all_bytes=0, coordinating_operation_bytes=859110825, max_coordinating_and_primary_bytes=858993459]"},"status":429}

所以最好设置"size":100

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值