微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

弹性搜索合并两个索引

如何解决弹性搜索合并两个索引

Reindex 不能用于合并两个索引。 Reindex 会在目标索引中进行完整更新。

考虑以下索引 my-new-index-000001

GET my-new-index-000001/_doc/6
{
  "_index" : "my-new-index-000001","_type" : "_doc","_id" : "6","_version" : 26,"_seq_no" : 34,"_primary_term" : 16,"found" : true,"_source" : {
    "field2" : "value2","field1" : "value1"
  }
}

上面的索引有两个字段field1和field2。

以下代码段用于将源字段 (new_field) 重新索引到目标:

# reindex that field
POST _reindex
{
  "source": {
    "index": ["my-index-000001"],"query": {
      "terms": {
        "_id": [6]
      }
    },"_source":["new_field"]
  },"dest": {
    "index": "my-new-index-000001"
  }
}

重新索引后,这是更新后的my-new-index-000001索引

GET my-new-index-000001/_doc/6
{
  "_index" : "my-new-index-000001","_version" : 27,"_seq_no" : 35,"_source" : {
    "new_field" : false
  }
}

有没有办法在弹性搜索中根据公共字段从源到目标进行部分更新? 有没有办法使用 python 脚本来实现这一点。 请分享一个工作片段或参考。

解决方法

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。