Elasticsearch 1.2.1 异常:解析后根类型映射不为空

2022-09-01 21:14:54

更新到Elasticsearch后,我在以下映射上不断收到以下异常:1.2.1

{
    "tags": {
        "properties": {
            "tags": {
                "type": "string",
                "index": "not_analyzed"
            }
        }
    }
}

这是例外:

Caused by: org.elasticsearch.index.mapper.MapperParsingException: Root type mapping not empty after parsing! Remaining fields: [tags : {properties={tags={index=not_analyzed, type=string}}}]
    at org.elasticsearch.index.mapper.DocumentMapperParser.parse(DocumentMapperParser.java:265)
    at org.elasticsearch.index.mapper.DocumentMapperParser.parseCompressed(DocumentMapperParser.java:189)
    at org.elasticsearch.index.mapper.MapperService.parse(MapperService.java:387)
    at org.elasticsearch.index.mapper.MapperService.merge(MapperService.java:253)
    at org.elasticsearch.cluster.metadata.MetaDataCreateIndexService$2.execute(MetaDataCreateIndexService.java:363)

为什么?


答案 1

@Mark这似乎是1.2.X中的一个错误。还有其他多个报告了类似的问题,我将链接到下面的票证。基本上,它们似乎加强了1.2.X中映射的语法,但它们似乎对以前有效的映射造成了一些问题。你的就是一个例子。

我建议你打开一个错误报告 - 更多的数字。如果您打开工单,很高兴说“我也是”,因为我已经在1.2.1上重现了这个问题。

现在,我已经能够进行以下工作,我相信这将为您提供相同的期望结果:

curl -XPUT localhost:9200/yourindexname -d 
'{
   "mappings":
   {
    "tags":
      {
       "properties":
         {
          "tags":
            {
             "type":"string",
             "index":"not_analyzed"
            }
          }
        }
    }
}'

票:

https://github.com/elasticsearch/elasticsearch/issues/6414

https://github.com/elasticsearch/elasticsearch/issues/6304

https://github.com/elasticsearch/elasticsearch/issues/6415


答案 2

这将对您有所帮助

你会得到你想做的想要

curl -XPUT localhost:9200/new_index -d '
{
  "mappings": { 
    "tags": {
      "properties": {
        "tags": { 
           "type":"string",
           "index":"not_analyzed"
        }
      }
    }
  }
}'

或者你也可以这样做

curl -XPUT localhost:9200/new_index/new_index_type/_mappings -d '
{
  "new_index_type": {
    "properties": {
      "tags": {
        "type": "string",
        "index": "not_analyzed"
      }
    }
  }
}'