簡體   English   中英

如何_reindex elasticsearch數據到新的映射(從平面字段到對象)?

[英]How to _reindex elasticsearch data to new mapping (from flat fields to objects)?

我有一個舊索引(elasticsearch索引)有超過20K個對象,此索引包含字段

{
    "title": "Test title",
    "title_ar": "عنوان تجريبي",
    "body": "<p>......</p>"
}

我想_reindex他們將所有數據轉換為這樣的新映射

{
    "title_1": {
        "en": "Test title",
        "ar": "عنوان تجريبي"
    },
    "body": "<p>......</p>"
}

在_reindex API中提供此轉換的最佳彈性搜索管道處理器是什么?

我建議簡單地使用reindex API來做到這一點:

POST _reindex
{
  "source": {
    "index": "old_index"
  },
  "dest": {
    "index": "new_index"
  },
  "script": {
    "source": "ctx._source.title = [ 'en' : ctx._source.title, 'ar': ctx._source.title_ar]",
    "lang": "painless"
  }
}

如果在old_index索引中,您具有以下內容:

{
    "title": "Test title",
    "title_ar": "عنوان تجريبي",
    "body": "<p>......</p>"
}

在新索引中,將具有以下內容:

{
    "title": {
        "en": "Test title",
        "ar": "عنوان تجريبي"
    },
    "body": "<p>......</p>"
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM