码迷,mamicode.com
首页 > 其他好文 > 详细

[Elasticsearch] 向已存在的索引中加入自己定义filter/analyzer

时间:2017-08-06 12:49:46      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:i++   cti   down   ddc   类型   except   ret   []   status   

问题描写叙述

随着应用的不断升级,索引中的类型也会越来越多,新添加的类型中势必会使用到一些自己定义的Analyzer。可是通过_settings端点的更新API不能直接在已经存在的索引上使用。

在sense中进行更新时会抛出异常:

PUT /symbol
{
  "settings": {
    "analysis": {
      "filter": {
        "edgengram": {
           "type": "edgeNGram",
           "min_gram": "1",
           "max_gram": "255"
        }
      },
      "analyzer": {
        "symbol_analyzer": {
          "type": "custom",
          "char_filter": [],
          "tokenizer": "standard",
          "filter": [
            "lowercase",
            "word_delimiter"
          ]
        },
        "back_edge_ngram_analyzer": {
          "type": "custom",
          "char_filter": [],
          "tokenizer": "whitespace",
          "filter": [
            "reverse",
            "edgengram",
            "reverse"
          ]
        }
      }
    }
  }
}

上例中,我们希望向名为symbol的索引中加入一个filter和两个analyzers。可是会抛出例如以下的错误信息:

{
   "error": "IndexAlreadyExistsException[[symbol] already exists]",
   "status": 400
}

提示我们该索引已经存在了,无法加入。


解决方式

最直观的解决方式是首先备份该索引中已经存在的数据。然后删除它再重建该索引。

这样的方式比較暴力,当索引中已经存在相当多的数据时。不建议这样做。

第二种方案是使用_open和_close这一对端点,首先将目标索引关闭,运行须要的更新操作,然后再打开该索引。

POST /symbol/_close

PUT /symbol/_settings
{
  "settings": {
    ....    
  }
}

POST /symbol/_open

这样就避免了须要重建索引的麻烦。

有了新加入的filter和analyzer。就能够依据须要再对types中的mappings进行更新了。

[Elasticsearch] 向已存在的索引中加入自己定义filter/analyzer

标签:i++   cti   down   ddc   类型   except   ret   []   status   

原文地址:http://www.cnblogs.com/yxysuanfa/p/7293927.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!