在无痛脚本中启用AWS Managed ElasticSearch上的正则表达式支持

时间:2017-11-13 18:43:41

标签: amazon-web-services elasticsearch aws-elasticsearch

我正在尝试将模板上传到我的AWS托管ElasticSearch。

ElasticSearch回答500错误,抱怨我需要将script.painless.regex.enabled设置为true。我知道您无法直接编辑elasticsearch.yml文件,但是无论如何都允许在AWS托管ES上的无痛脚本中支持正则表达式?

1 个答案:

答案 0 :(得分:0)

还没有办法在AWS ES集群下使用正则表达式。

您可以尝试使用StringTokenizer,如下例:

示例值:

doc['your_str_field.keyword'].value = '{"xxx":"123213","yyy":"123213","zzz":"123213"}'

无痛脚本:

{
"script": {
"lang": "painless",
"inline": "String xxx = doc['your_str_field.keyword'].value; xxx = xxx.replace('{','').replace('}','').replace('\"','').replace(' ','');StringTokenizer tokenizer = new StringTokenizer(xxx, ',');tokenizer.nextToken();tokenizer.nextToken();StringTokenizer tokenizer_v = new StringTokenizer(tokenizer.nextToken(),':');tokenizer_v.nextToken();return tokenizer_v.nextToken();"
}
}

另外,我需要提高max_compilations_rate

PUT /_cluster/settings
{
"transient": {
  "script.max_compilations_rate": "500/1m"
}
}