📣 极限科技诚招搜索运维工程师(Elasticsearch/Easysearch)- 全职/北京 👉 : 立即申请加入

版本: 6.8-7.15

简而言之,当 Elasticsearch 无法解析监视器的特定操作时会发生此错误。这可能是由于监视器定义中的语法不正确、缺少字段或数据类型无效导致的。要解决此问题,首先应该验证监视器定义的语法。确保包含所有必需字段,并且数据类型正确。如果错误仍然存在,尝试通过简化监视器定义来隔离有问题的部分,然后逐渐增加复杂性,直到错误再次出现。这将帮助您确定问题的确切原因。

日志上下文 #

日志 “could not parse [{}] action for watch [{}]. failed to parse [{}]. must be” 的类名是 IndexAction.java。我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考:

timeout = WatcherDateTimeUtils.parseTimeValue(parser, Field.TIMEOUT_HUMAN.toString());
} else if (Field.DYNAMIC_NAME_TIMEZONE.match(currentFieldName, parser.getDeprecationHandler())) {
    if (token == XContentParser.Token.VALUE_STRING) {
        dynamicNameTimeZone = DateUtils.of(parser.text());
    } else {
        throw new ElasticsearchParseException("could not parse [{}] action for watch [{}]. failed to parse [{}]. must be " +
            "a string value (e.g. 'UTC' or '+01:00').", TYPE, watchId, currentFieldName);
    }
} else if (Field.REFRESH.match(currentFieldName, parser.getDeprecationHandler())) {
    refreshPolicy = RefreshPolicy.parse(parser.text());
} else {