我正在尝试将模板上传到我的AWS托管ElasticSearch。
ElasticSearch回答500错误,抱怨我需要将script.painless.regex.enabled
设置为true
。我知道您无法直接编辑elasticsearch.yml
文件,但是无论如何都允许在AWS托管ES上的无痛脚本中支持正则表达式?
答案 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"
}
}