脚本化度量聚合在意外=字符时失败

rryofs0p  于 2021-06-14  发布在  ElasticSearch
关注(0)|答案(0)|浏览(552)

我正在尝试使某个对象包含具有相同recordid的两个日志之间的所有时间增量。
为此,我使用fiddler在elastic search上执行以下查询(脚本化度量聚合),其中包含日志:

{
    "query": {
        "exists": {
            "field": "recordId"
        }
    },
    "aggs": {
        "deltas": {
            "scripted_metric": {
                "init_script": {
                    "source": "state.deltas = {};",
                    "lang": "expression"
                },
                "map_script": {
                    "source": " if (!(doc['topic'].value in state.deltas)) { state.deltas[doc['topic'].value] = {} } state.deltas[doc['topic'].value][doc['recordId'].value] = !(doc['recordId'].value in state.deltas[doc['topic'].value]) ? doc['@timestamp'].date.millisOfDay : Math.abs(state.deltas[doc['topic'].value][doc['recordId'].value] - doc['@timestamp'].date.millisOfDay) ",
                    "lang": "expression"
                },
                "reduce_script": {
                    "source": " res = {}; for (s in states) { for(topic in Object.keys(s.deltas)) { if (!(topic in res)) { res[topic] = {} } for(recordId in Object.keys(s.deltas[topic])) { res[topic][recordId] = !(recordId in res[topic]) ? s.deltas[topic][recordId] : Math.abs(res[topic][recordId] - s.deltas[topic][recordId]) } } } return res;",
                    "lang": "expression"
                }
            }
        }
    }
}

但由于意外的“=”字符而失败。。。尝试了其他方法,但总是抛出相同的错误。
我错过了什么?

{
  "error": {
    "root_cause": [
      {
        "type": "lexer_no_viable_alt_exception",
        "reason": "lexer_no_viable_alt_exception: null"
      }
    ],
    "type": "search_phase_execution_exception",
    "reason": "all shards failed",
    "phase": "query",
    "grouped": true,
    "failed_shards": [
      {
        "shard": 0,
        "index": "il0:il1-sys-logs-2020.10.07",
        "node": "5bmIYI_iSVCtx41qEEbASg",
        "reason": {
          "type": "script_exception",
          "reason": "compile error",
          "script_stack": [
            "state.deltas = {};",
            "             ^---- HERE"
          ],
          "script": "state.deltas = {};",
          "lang": "expression",
          "caused_by": {
            "type": "parse_exception",
            "reason": "parse_exception: unexpected character '= ' on line (1) position (13)",
            "caused_by": {
              "type": "lexer_no_viable_alt_exception",
              "reason": "lexer_no_viable_alt_exception: null"
            }
          }
        }
      }
    ],
    "caused_by": {
      "type": "lexer_no_viable_alt_exception",
      "reason": "lexer_no_viable_alt_exception: null"
    }
  },
  "status": 500
}

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题