2

在我的应用程序中,我为每个国家/地区的 websocket ping 时间设置了直方图,每个国家/地区一个直方图。在 Grafana 中,我通过以下查询获得了我最感兴趣的几个国家/地区的平均 ping 时间图表

rate(country_ping_sum{country=~"AU|NZ|CA|GB|US",instance="$instance"}[15m]) / rate(country_ping_count{country=~"AU|NZ|CA|GB|US",instance="$instance"}[15m])

这工作得很好。我得到了每个国家的图表。现在我想将所有其他国家的平均值加到同一张图中。

avg(rate(country_ping_sum{country!~"AU|NZ|CA|GB|US",instance="$instance"}[15m]) / rate(country_ping_count{country!~"AU|NZ|CA|GB|US",instance="$instance"}[15m]))

这失败了。当我在 Prometheus 控制台的 Prometheus 查询中尝试查询时,我得到一个 NaN 值。如果我采用相同的查询并删除 avg() 函数,那么我会得到每个匹配国家/地区的列表,有些有值,有些有 NaN。许多国家的总和和计数的比率均为 0。显然,对于那些特定国家,这些除以 0 等于 NaN。

所以我的问题是,如何在传递给 avg() 之前过滤掉 NaN 值?

4

1 回答 1

6

您实际上是在取平均值,这通常是不正确的。

而是sum对 each做一个rate,然后除以得到整体平均值。

于 2016-12-13T22:19:20.087 回答