排序
本节我们将学习如何对查询结果进行排序,或者只选择一组序列中最大或最小的值。
我们可以使用 sort()
(升序) 或者 sort_desc()
(降序)函数来实现对输出结果进行排序,例如,要显示按值排序的每个路径请求率,从最高到最低,我们可以用下面的语句进行查询:
sort_desc(sum by(path) (rate(demo_api_request_duration_seconds_count{job="demo"}[5m])))
有的时候我们并不是对所有的时间序列感兴趣,只对最大或最小的几个序列感兴趣,我们可以使用 topk()
和 bottomk()
这两个运算符来操作,可以返回 K
个最大或最小的序列,比如只显示每个 path 和 method 的前三的请求率,我们可以使用下面的语句来查询。
topk(3, sum by(path, method) (rate(demo_api_request_duration_seconds_count{job="demo"}[5m])))
练习
1.构建一个查询以升序的方式显示所有 3 个 demo 服务的磁盘使用情况。
sort(demo_disk_usage_bytes)
2.构建一个查询,按 method、path 和 status 维度显示 3 个最低流量的 demo API 请求比率。
bottomk(3, sum by(method, path, status) (rate(demo_api_request_duration_seconds_count[5m])))