Elasticsearch“strict”映射不适用于具有空值的字段

时间:2015-10-21 18:50:08

标签: elasticsearch elasticsearch-mapping

我有一个索引,我已将映射设置为"dynamic":"strict"

正如预期的那样,在大多数情况下,如果引入了映射中未列出的字段,Elasticsearch将拒绝该字段。
但是我发现任何具有null值的字段都没有被捕获,并且会进入我的索引。这是我的映射的样子:

{
 "myindex": {
    "mappings": {
       "mystuff": {
          "dynamic": "strict",
          "_id": {
             "store": true,
             "index": "not_analyzed"
          },
          "_timestamp": {
             "enabled": true,
             "store": true
          },
          "_index": {
             "enabled": true
          },
          "_type": {
             "store": true
          },
          "properties": {
             "entitlements": {
                "type": "nested",
                "properties": {
                   "accountNumber": {
                      "type": "string",
                      "index": "not_analyzed"
                   },
                   "active": {
                      "type": "string",
                      "index": "not_analyzed"
                   },
                   "assetEndDate": {
                      "type": "date",
                      "format": "date_time_no_millis"
                   }
                 }
              }
           }
        }
     }
  }
}

编辑(包括示例场景)

通过上面的映射,以下是我看到的情景:

1)发布有效文件(映射后的文件)时,200 OK

发布文件:

{
    "entitlements": [
        {
            "accountNumber": "123213",
            "active": "true",
            "assetEndDate": "2016-10-13T00:00:00Z"
        }
    ]
}

elasticsearch response:

{
  "_index": "myindex",
  "_type": "mystuff",
  "_id": "5",
  "_version": 1,
  "created": true
}

2)发布无效文档(不遵循映射的文档)时,400 StrictDynamicMappingException

发布文件:

{
  "entitlements": [
    {
      "accountNumber":"123213",
      "XXXXactive": "true",
      "assetEndDate": "2016-10-13T00:00:00Z"
    }     
  ] 
}

elasticsearch response:

{
 "error": "StrictDynamicMappingException[mapping set to strict, dynamic introduction of [Xactive] within [entitlements] is not allowed]",
 "status": 400
}

3)发布无效文档(不遵循映射的文档)时,对于无效字段null,值为200 OK

发布文件:

{
  "entitlements": [
    {
      "accountNumber":"123213",
      "XXXXactive": null,
      "assetEndDate": "2016-10-13T00:00:00Z"
    }     
  ] 
}

elasticsearch response:

{
  "_index": "myindex",
  "_type": "mystuff",
  "_id": "7",
  "_version": 1,
  "created": true
}

4)发布无效文档(不遵循映射的文档)时,对于无效字段null,值为200 OK

发布文件:

{
  "entitlements": [
    {
      "accountNumber":"123213",
      "XXXXactive": null,
      "assetEndDate": "2016-10-13T00:00:00Z",
      "THIS_SHOULD_NOT_BE_HERE": null
    }     
  ] 
}

elasticsearch response:

{
  "_index": "myindex",
  "_type": "mystuff",
  "_id": "9",
  "_version": 1,
  "created": true
}

这是第三和第四种情况,我很担心。

看起来这个问题(或者一个非常类似的问题)是Elasticsearch git存储库here引发的,并且此后一直关闭。但是,问题似乎仍然是版本1.7中的问题。

本地以及我使用AWS Elasticsearch服务部署的索引都可以看到这一点。

我在某个地方犯了错误,或者有没有人找到解决这个问题的方法?

0 个答案:

没有答案