我有一个索引,我已将映射设置为"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
服务部署的索引都可以看到这一点。
我在某个地方犯了错误,或者有没有人找到解决这个问题的方法?