20

我有一个应用程序,它在接收到特定的 HTTP 请求时增加 Prometheus 计数器。该应用程序在 Kubernetes 中运行,具有多个实例并每天重新部署多次。使用该查询http_requests_total{method="POST",path="/resource/aaa",statusClass="2XX"}会生成一个图表,按预期显示每个实例的累积请求计数。

我想创建一个 Grafana 图表,显示过去 7 天收到的请求的累积频率。

我的第一个想法是用于increase(...[7d])考虑从 7 天窗口之外开始的任何指标(如显示的图像中所示),然后sum是这些值。

我已经意识到sum(increase(http_requests_total{method="POST",path="/resource/aaa",statusClass="2XX"}[7d]))实际上确实给出了时间点的正确答案。但是,结果图并不完全符合要求,因为组件increase(...) 值在一周内增加/减少。

我将如何创建一个图表来显示过去 7 天内这些指标的累计增长总和?例如,给定以下简化数据

| Day | # Requests |
|-----|------------|
| 1   | 10         |
| 2   | 5          |
| 3   | 15         |
| 4   | 10         |
| 5   | 20         |
| 6   | 5          |
| 7   | 5          |
| 8   | 10         |

如果我要查看第 2 天到第 8 天的图表,我希望图表呈现如下线条,

| Day | Cumulative Requests |
|-----|---------------------|
| d0  | 0                   |
| d1  | 5                   |
| d2  | 20                  |
| d3  | 30                  |
| d4  | 50                  |
| d5  | 55                  |
| d6  | 60                  |
| d7  | 70                  |

其中d0表示图中的初始值

谢谢

4

1 回答 1

0

如果我正确理解了您的问题的想法,我想我设法用这样的查询创建了这样的图表

sum(max_over_time(counterName{someLabel="desiredlabelValue"}[7d]))

它生成的图表看起来像蓝色的:过去 7 天内累计处理

图表的未来部分减少的原因既是因为未来处理还没有明显发生,也是因为超过 7 天的处理滑出移动的 7 天检查窗口。

于 2021-09-07T11:59:06.210 回答