Запрос диапазона дат с использованием шаблона поиска в Elasticsearch
Мы столкнулись с проблемой при формировании запроса диапазона дат с использованием шаблона поиска в Elasticsearch. Он работает нормально, с одним условным предложением, но при наличии нескольких условий мы получаем следующую ошибку.
{
"script": {
"lang": "mustache",
"source": "{
\"query\":{
\"bool\":{
\"must\":[
{{#since}}
{\"range\":
{\"@timestamp\":
{
{{#from}}\"from\":\"{{from}}\"{{/from}}
}
}
},{{/since}}
{\"query_string\":
{
\"query\":\"(title:({{query_string}}))\"
}
}
]
}
}
}"
}
}
Ошибка:
{
error: {
root_cause: [
{
type: "general_script_exception",
reason: "Failed to compile stored script [dateTemplate] using lang [mustache]",
}
],
type: "general_script_exception",
reason: "Failed to compile stored script [dateTemplate] using lang [mustache]",
caused_by: {
type: "mustache_exception",
reason: "Improperly closed variable in query-template:1",
},
},
status: 500,
}
Запрос:
{"id": "dateTemplate", "params": {"query_string": "*"}}
То же самое работает нормально для этого шаблона:
{
"script": {
"lang": "mustache",
"source": "{\"query\":{\"bool\":{\"must\":[{{#since}}{\"range\": {\"@timestamp\": {\"from\": \"{{since}}\"}}},{{/since}}{\"query_string\":{\"query\":\"(title:({{query_string}}))\"}}]}}}"
}
}
запрос
{
"id": "date",
"params": {
"query_string": "*",
"since": "2018-07-23"
}
}
1 ответ
Решение
Прежде всего, я предлагаю вам переписать свой шаблон с помощью тройных кавычек, так как его гораздо проще читать и поддерживать, например так:
POST _scripts/dateTemplate
{
"script": {
"lang": "mustache",
"source": """
{
"query": {
"bool": {
"must": [
{{#since}}
{
"range": {
"@timestamp": {
{{#from}}"from": "{{from}}"{{/from}}
}
}
},
{{/since}}
{
"query_string": {
"query": "(title:({{query_string}}))"
}
}
]
}
}
}
"""
}
}
Тогда правильный способ вызова этого запроса выглядит следующим образом (т.е. from
переменная в вашем объекте params):
{
"id": "dateTemplate",
"params": {
"query_string": "*",
"since": {
"from": "2018-07-23"
}
}
}