0x00 概述
在进行Prometheus查询或者新增Prometheus Alerts时候,会出现报错could not parse expression: parse error at char 107: range specification must be preceded by a metric selector;
初步看以为是查询语句写错了,其实此处是查询语句包含SubQuery导致的问题,是Prometheus版本过低导致的。
0x01 问题现象
在版本为2.1的Prometheus上查询最近7天的CPU最大利用率的时候,返回报错,报错可以参考此issue,
查询语句为:
sum(max_over_time(irate(container_cpu_usage_seconds_total{namespace!='',container_name!='',container_name!='POD}[5m])[7d:1m])*100) by (namespace,container_name)";
查询语句中使用了2个函数,分别为max_over_time和sum;
0x02 问题解决
在Prometheus的理解中,是将max_over_time查询后再进行了sum查询,官方定义为subQuery;
根据官方的文档,subQuery功能是在版本2.7才加入的,所以如果出现以上报错,请检查Prometheus版本是否低于2.7;
如果版本是高于2.7,则说明是查询语句有问题,需要修改查询语句。