У меня есть счетчик, скажем, port.packets, и я хочу вычислить кумулятивную сумму на пути сегментов нормализованного значения производных по единицам вместо фактического производного значения.
Обычно кумулятивная сумма принимает имяпути производных сегментов, можно ли как-нибудь указать путь сегментов как нормализованное значение?
{
"size":0,
"query":{
// some query
},
"aggregations":{
"termsAgg":{
"terms":{
"field":"portIdToClusterId",
"size":1000,
"order":[
{
"_count":"desc"
},
{
"_key":"asc"
}
]
},
"aggregations":{
"dateHistogramAgg":{
"date_histogram":{
"field":"timestamp",
"missing":0,
"interval":"5m",
"offset":0,
"order":{
"_key":"asc"
},
"keyed":false,
"min_doc_count":0
},
"aggregations":{
"maxAggportrxpackets":{
"max":{
"field":"portpackets"
}
},
"derAggportrxpackets":{
"derivative":{
"buckets_path":[
"maxAggportrxpackets"
],
"gap_policy":"skip",
"unit":"1s"
}
},
"cumSumAggportrxpackets":{
"cumulative_sum":{
"buckets_path":[
"derAggportrxpackets" // I want to take the normalized value instead of directly derivative
]
}
}
}
}
}
}
}
}
Sample output :
"aggregations" : {
"termsAgg" : {
"doc_count_error_upper_bound" : 0,
"sum_other_doc_count" : 0,
"buckets" : [
{
"key" : "1_3_x8::10.115.32.163",
"doc_count" : 12,
"dateHistogramAgg" : {
"buckets" : [
{
"key_as_string" : "2019-10-25T16:20:00.000Z",
"key" : 1572020400000,
"doc_count" : 1,
"maxAggportrxpackets" : {
"value" : 1.86446649842E11
},
"cumSumAggportrxpackets" : {
"value" : 0.0
}
},
{
"key_as_string" : "2019-10-25T16:25:00.000Z",
"key" : 1572020700000,
"doc_count" : 1,
"maxAggportrxpackets" : {
"value" : 1.86446649852E11
},
"derAggportrxpackets" : {
"value" : 10.0,
"normalized_value" : 0.03333333333333333
},
"cumSumAggportrxpackets" : {
"value" : 10.0
}
},
{
"key_as_string" : "2019-10-25T16:30:00.000Z",
"key" : 1572021000000,
"doc_count" : 1,
"maxAggportrxpackets" : {
"value" : 1.86446649862E11
},
"derAggportrxpackets" : {
"value" : 10.0,
"normalized_value" : 0.03333333333333333
},
"cumSumAggportrxpackets" : {
"value" : 20.0 // Here I want the cum sum on the normalized_value of the derivative rather than actual derivative
}
}