elasticsearch使用reindex重建索引

创建索引以后,索引的设定和很多固定配置将不能改变,如果需要改变数据结构就需要重建索引
Elasticsearch v6.3.1以后支持Reindex API重建索引
已有索引库book和book_new
book为源索引,book_new为目标索引
整个过程为book重建索引到book_new
如果不手动创建book_new的mapping信息,elasticsearch将自动映射数据类型

POST _reindex
{
  "source": {
    "index": "book"
  },
  "dest": {
    "index": "book_new",
    "version_type": "internal"
  }
}

参数配置

version_type

在修改数据的时候es会修改数据的version
在这里插入图片描述
version_type会对迁移的_version做出处理

  1. internal:直接拷贝文档到目标索引,对相同的type、文档ID直接进行覆盖,默认值
  2. external:迁移文档到目标索引时,保留version信息,对目标索引中不存在的文档进行创建,已 存在的文档按version进行更新,遵循乐观锁机制。
op_type

op_type设置为create,那么源索引库的文档迁移到目标库的时候,只会迁移源库有id而目标库没有的id的文档,已存在的会提示错误信息

POST _reindex
{
  "conflicts": "proceed",
  "source": {
    "index": "book"
  },
  "dest": {
    "index": "book_new",
    "op_type": "create"
  }
}

如果加上"conflicts": “proceed”,则不提示错误信息

query

reindex api支持数据过滤、数据排序、size设置、_source选择等
迁移price大于10小于400的

POST _reindex
{
  "conflicts": "proceed",
  "source": {
    "index": "book",
    "query": {
      "range": {
        "price": {
          "gte": 10,
          "lte": 400
        }
      }
    }
  },
  "dest": {
    "index": "book_new",
    "op_type": "create"
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值