prometheus 查询例子
所属分类 prometheus
浏览量 2553
https://prometheus.io/docs/prometheus/latest/querying/examples/
PromQL (Prometheus Query Language)
Return all time series with the metric http_requests_total:
http_requests_total
根据标签过滤
http_requests_total{job="apiserver", handler="/api/comments"}
Return a whole range of time (in this case 5 minutes) for the same vector, making it a range vector
http_requests_total{job="apiserver", handler="/api/comments"}[5m]
Note that an expression resulting in a range vector cannot be graphed directly, but viewed in the tabular ("Console") view of the expression browser.
不能直接绘图 ,但是可以在 console里查看数据
使用正则表达式 过滤
http_requests_total{job=~".*server"}
all jobs that end with server
. 任意字符
.* 匹配 0到多个任意字符
select all HTTP status codes except 4xx ones
http_requests_total{status!~"4.."}
RE2 syntax
https://github.com/google/re2/wiki/Syntax
Subquery 子查询
Return the 5-minute rate of the http_requests_total metric for the past 30 minutes, with a resolution of 1 minute.
rate(http_requests_total[5m])[30m:1m]
rate(total_pv[5m])[30m:1m]
执行报错
Error executing query: parse error at char 19: range specification must be preceded by a metric selector, but follows a *promql.Call instead
使用函数
Return the per-second rate for all time series with the http_requests_total metric name, as measured over the last 5 minutes:
rate(http_requests_total[5m])
rate(total_pv[5m])
increase(total_pv[5m])
根据时间窗口聚合计算
node_filesystem_avail_bytes
node_filesystem_avail_bytes{device="tmpfs",fstype="tmpfs",instance="localhost:9100",job="node_exporter",mountpoint="/run/user/0"}
node_filesystem_avail_bytes{device="tmpfs",fstype="tmpfs",instance="localhost:9100",job="node_exporter",mountpoint="/run"}
node_filesystem_avail_bytes{device="rootfs",fstype="rootfs",instance="localhost:9100",job="node_exporter",mountpoint="/"}
node_filesystem_avail_bytes{device="/dev/vda1",fstype="ext3",instance="localhost:9100",job="node_exporter",mountpoint="/"}
sum(node_filesystem_avail_bytes)
sum by (device) (node_filesystem_avail_bytes)
{device="tmpfs"}
{device="rootfs"}
{device="/dev/vda1"}
sum by (device) 保留 device 标签
类似 sql 中的 group by
count (node_filesystem_avail_bytes)
4
topk(1, count by (device) (node_filesystem_avail_bytes) )
topk(2, sum by (device) (node_filesystem_avail_bytes))
topk(1, sum by (device) (node_filesystem_avail_bytes))
上一篇
下一篇
prometheus中的时间序列数据
grafana数据接口
grafana 日PV 柱状图
springboot ApplicationContextInitializer 使用
日志框架冲突及解决方法
linux熵池太小导致随机函数阻塞