首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ElastAlert: config.yaml :聚合选项提供错误

ElastAlert: config.yaml :聚合选项提供错误
EN

Stack Overflow用户
提问于 2018-04-05 23:06:05
回答 1查看 1.3K关注 0票数 0

我已经在中配置了config.yaml聚合选项,以便每隔1小时发送一次警报摘要。但当我试图运行它时,它会抛出以下错误。

代码语言:javascript
复制
File "elastalert.py", line 863, in run_rule
self.add_aggregated_alert(match, rule)
File "elastalert.py", line 1614, in add_aggregated_alert
alert_time = ts_now() + rule['aggregation']
TypeError: unsupported operand type(s) for +: 'datetime.datetime' and 'dict'
ERROR:root:Uncaught exception running rule Test Alert : unsupported operand type(s) for +: 'datetime.datetime' and 'dict'
INFO:elastalert:Rule Test Alert disabled

配置参数如下:

代码语言:javascript
复制
rules_folder: test_rules
run_every:
 minutes: 15
buffer_time:
 minutes: 30
es_host: 100.38.46.3
es_port: 9200
aggregation:
 hours: 1
writeback_index: elastalert_status
alert_time_limit:
  days: 2

测试警报规则配置:

代码语言:javascript
复制
name: Test Alert
type: metric_aggregation
index: logstash-*
buffer_time: 
 minutes: 30
metric_agg_key: count
metric_agg_type: sum
query_key: "name.keyword"
doc_type: counter
max_threshold: 1
min_threshold: 0
filter:
- query:
   query_string: 
     query: "name.keyword: *timedout_count"
alert:
- "email"
email:
- "admin@abc.com"

我跟踪了ElastAlert文档,但无法找出是什么导致了这个问题。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2018-05-15 01:21:48

从错误:

代码语言:javascript
复制
TypeError: unsupported operand type(s) for +: 'datetime.datetime' and 'dict'

从你的config.yaml

代码语言:javascript
复制
metric_agg_type: sum

它试图(和失败)对不支持求和的datetime和dict值执行和聚合。您可能需要选择一个诸如count或唯一计数之类的聚合,并相应地调整警报的逻辑。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49682835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档