创建索引时,添加了新的分析器analyzer_keyword
- 请参阅下面的创建索引
curl -XPUT 'http://mycluster/dsi2' -d '{
"settings": {
"index": {
"number_of_shards": 1,
"number_of_replicas": 1,
"analysis": {
"analyzer": {
"analyzer_keyword": {
"tokenizer": "keyword",
"filter": "lowercase"
}
}
}
}
}
}
运行_settings
端点确认以下
http GET http://mycluster/dsi2/_settings
HTTP/1.1 200 OK
Access-Control-Allow-Origin: *
Connection: keep-alive
Content-Length: 267
Content-Type: application/json; charset=UTF-8
{
"dsi2": {
"settings": {
"index": {
"analysis": {
"analyzer": {
"analyzer_keyword": {
"filter": "lowercase",
"tokenizer": "keyword"
}
}
},
"creation_date": "1484088347598",
"number_of_replicas": "1",
"number_of_shards": "1",
"uuid": "Lu98fn6gRiOe3Q1y8fU6tQ",
"version": {
"created": "2030299"
}
}
}
}
}
但现在在创建mapping
时 - (以下是带有相关字段的部分映射json)
curl -XPUT 'http://mycluster/_mapping/dsi2' -d '{
"_all": {
"enabled": true
},
"properties": {
"mainId" : {
"type" : "integer"
},
"instance": {
"properties": {
"id": {
"type": "integer",
"fields": {
"raw": {
"type": "integer",
"index": "not_analyzed"
}
它抛出
[{"error":{"root_cause": [{"type":"mapper_parsing_exception","reason":"analyzer [analyzer_keyword] not found for field [raw]"}],"type":"mapper_parsing_exception","reason":"analyzer [analyzer_keyword] not found for field [raw]"},"status":400}
任何想法为什么它无法找到创建索引一部分的analyzer_keyword
映射?这是针对Elastic版本2.3的Amazon EC2 ElasticService实例
编辑 - 感谢Val的回应。
@Val - 感谢您的回复。在你指出重新创建索引之后 - 我在创建映射时仍然遇到相同的错误。
当我运行GET http://mycluster/dsi2/_settings
时,它会向我显示
{
"dsi2": {
"settings": {
"index": {
"analysis": {
"analyzer": {
"analyzer_keyword": {
"filter": "lowercase",
"tokenizer": "keyword"
}
}
},
"creation_date": "1484146006348",
"number_of_replicas": "1",
"number_of_shards": "1",
"uuid": "HzjQjZXmS8SPF6yUFZanEQ",
"version": {
"created": "2030299"
}
}
}
}
}
答案 0 :(得分:5)
这是因为analysis
部分直接位于settings
下方,而不是settings > index
。
您可以像这样重新创建索引,它将起作用:
curl -XPUT 'http://mycluster/dsi2' -d '{
"settings": {
"index": {
"number_of_shards": 1,
"number_of_replicas": 1
},
"analysis": {
"analyzer": {
"analyzer_keyword": {
"tokenizer": "keyword",
"filter": "lowercase"
}
}
}
}
}