Я следую приведенному здесь совету, чтобы найти частичные слова сластиком поиска:
В n-граммовом токен-фильтре ElasticSearch не найдены частичные слова
У меня естьсоздал простой bash-скрипт, который пытается запустить версию этого:
curl -XDELETE 10.160.86.134:9200/products
curl -XPOST 10.160.86.134:9200/products -d '{
"index": {
"number_of_shards": 1,
"analysis": {
"filter": {
"mynGram" : {"type": "nGram", "min_gram": 2, "max_gram": 10}
},
"analyzer": {
"a1" : {
"type":"custom",
"tokenizer": "standard",
"filter": ["lowercase", "mynGram"]
}
}
}
}
}
}'
curl -XPUT 10.160.86.134:9200/products/_mapping -d '{
"product" : {
"index_analyzer" : "a1",
"search_analyzer" : "standard",
"properties" : {
"product_description": {"type":"string"},
"product_name": {"type":"string"}
}
}
}'
После запуска этого скрипта первые две команды (выгрузка продуктов, затем установка индекса), кажется, дают мне следующее:
{"ok":true,"acknowledged":true}
{"ok":true,"acknowledged":true}
Тогда после вызова сопоставления возникает ошибка:
{"error":"ActionRequestValidationException[Validation Failed: 1: mapping type is missing;]","status":500}
Кто-нибудь может увидеть, что я делаю неправильно?Поиск в Google запускает автозаполнение "mapping not foundasticsearch", поэтому, похоже, это очень распространенная ошибка.