目标是仅使用相关文档组中的最新文档构建Elasticsearch索引,以跟踪某些监控计数器和状态的当前状态。
我制作了一个简单的 Elasticsearch聚合查询:
{
"size": 0,
"aggs": {
"group_by_monitor": {
"terms": {
"field": "monitor_name"
},
"aggs": {
"get_latest": {
"top_hits": {
"size": 1,
"sort": [
{
"timestamp": {
"order": "desc"
}
}
]
}
}
}
}
}
}
它将相关文档分组到存储桶中,并为每个存储桶选择最新文档。
以下是我完成工作所需的不同想法:
是否有一种相当复杂的方法来实现这一目标?
答案 0 :(得分:3)
编辑logstash.conf
文件,如下所示
input {
elasticsearch {
hosts => "localhost"
index => "source_index_name"
type =>"index_type"
query => '{Query}'
size => 500
scroll => "5m"
docinfo => true
}
}
output {
elasticsearch {
index => "target_index_name"
document_id => "%{[@metadata][_id]}"
}
}