Prometheus-PQL

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Prometheus-PQL相关的知识,希望对你有一定的参考价值。

参考技术A 以容器内存使用量container_memory_usage_bytes等时序为例,演示PQL的语法

容器很多,每个容器都有container_memory_usage_bytes这个时序,所以会查询出很多值
以下是一条完整的时间序列:

时序通常包含很多标签,可以使用字符串、正则表达式来过滤标签值。支持的运算: =: 等于、!=: 不等于、=~: 匹配正则表达式、!~: 不匹配正则表达式

在上一个查询的基础上,增加2分钟的时间范围,获取2分钟内的多个值

时间范围的单位可以是:s秒s分h 小时d 天w周y年;
时间范围2分钟,可以看到3到4个值,说明target是每30s获取一次,查询结果中可以看到时间戳

获取3分钟前到1分钟前的多个值,时间范围2m,必须在offset之前

可以通过数学运算,改变查询出来的值:
支持的运算符:+ 、- 、*、/ 、% (取模)、^ (幂)

通过比较运算,过滤出符合条件的值
支持的比较运算符:== (等于)、!= (不等于)、> (大于)、< (小于)、>= (大于等于) <= (小于等于)

还可以在比较运算符后加上bool,返回比较结果,1表示True,0表示false,不过滤

比较时,前面的值是标量,必须使用bool,返回1或者0

支持 and、or、unless运算,不支持值的运算

将A和B两个结果合并

A和B的标签必须完全一致,查询结果保留A的名称、值和标签,不完全一致的丢弃

A unless B:
删除A中与B标签完全匹配的时序,保留不匹配的

<vector expr>向量表达式
<bin-op>算术运算
Ignoring 忽略标签、on选定标签
默认需要匹配所有标签,可以选择忽略,或者只选择某些标签

原始数据如下:

获取method_code:http_errors:rate5m中标签code="500"的向量

除以method:http_requests:rate5m中标签method标签相同
(method_code:http_errors:rate5m包含method和code两个标签,由于忽略了code,所以只匹配method)的向量,查询结果如下:

增加了group_left、group_right操作:

忽略code标签,匹配method标签,group_left表示多对一,group_right表示一对多,在结果中保留多一侧的所有标签

支持的运算有:

可以配合by或者without进行标签过滤

MATLAB编程与应用系列-第2章 数组及矩阵的创建及操作

本系列教程来源于出版设计《基于MATLAB编程基础与典型应用书籍》,如涉及版权问题,请联系:[email protected]。 出版社:人民邮电出版社, 页数:525。

本系列教程目前基于MATLABR2006a,可能对于更高级版本的功能和函数有差异,教程中如有问题,请联系:[email protected]

2.3 多维数组

###2.3.1 多维数组的创建
在MATLAB中创建和使用一维和两维数组十分灵活,同样MATLAB也提供了灵活多样的创建多维数组的方法,使得用户可以根据自己所创建多维数组的特征选取不同的创建方法。其中最常用的创建方法有:第一通过“全下标”元素赋值方式创建多维数组;第二由函数ones、zeros、rand和randn直接创建多维数组;第三借助构造函数创建多维数组。下面通过示例讲解如何使用不同的方法创建多维数组。

(1)通过“全下标”元素赋值方式创建多维数组

【例2.15】“全下标”方式创建多维数组
在MATLAB命令行窗口中输入以下命令,创建一个二维的四阶魔方阵:
&gt;&gt; A=magic(4) %生成一个二维的四阶魔方阵
以矩阵A为基础,通过直接定义数组的第三维的方式,创建一个三维数组。在命令窗口中输入:
&gt;&gt; A(:,:,2)=rand(4) %四阶的随机阵
上述语句的执行结果如下所示。
A(:,:,1) =<br/>16 2 3 13<br/>5 11 10 8<br/>9 7 6 12<br/>4 14 15 1
A(:,:,2) =<br/>0.4451 0.8462 0.8381 0.8318<br/>0.9318 0.5252 0.0196 0.5028<br/>0.4660 0.2026 0.6813 0.7095<br/>0.4186 0.6721 0.3795 0.4289

(2)由函数ones、zeros、rand和randn直接创建多维数组
前面介绍到了使用函数ones、zeros、rand和randn可以直接生成二维数组,除了生成二维数组的功能外,这些函数还可以生成多维数组。

【例2.16】用函数ones、zeros、rand和randn直接创建三维随机数组
&gt;&gt; A=rand(4,5,3) %创建三维随机数组
&gt;&gt; B=ones(4,2,6) %创建三维的单位矩阵
&gt;&gt; C=zeros(4,6,8); %创建三维的零值矩阵

(3)借助构造函数创建多维数组
多维数组的构造函数很多,如cat、repmat、reshape等,在这里主要介绍几个常用的构造函数。表2.5所示为使用cat, repmat和reshape函数构造多维数组的函数调用格式和函数描述。
函数名 调用格式 函数描述
Cat A=cat(n,A1,A2,…,Am) n=1和n=2时分别构造[A1;A2]和[A1,A2],它们都是二维数组,而n=3时可以构造出三维数组
repmat repmat(p,行 列 页 ……) 第一个输入变量p是用来放置的模块数组,后面的变量是要放置指定的维数。
reshape reshape(p,行 列 页 ……) 第一个变量是待重组的数组p,后面的变量是重新生成数组的行数、列数、页数等。

【例2.17】构造函数cat、repmat、reshape创建多维数组
首先生成构造函数使用的两个矩阵A和B,具体如下:
&gt;&gt; A=rand(4) %二维数组A
&gt;&gt; B=rand(4) %二维数组B
以下使用cat函数生成一个新的二维数组n=2,在命令窗口中输入:
&gt;&gt; C=cat(2,A,B)
使用cat函数生成一个新的三维数组n=3,在命令窗口中输入:
&gt;&gt; D=cat(3,A,B)

注意:使用reshape函数时要注意新生成的矩阵元素数量不变,否则无法生成。

###2.3.2 多维数组的标识
MATLAB中提供了许多指令可以用来判断数组的维数和大小等操作的函数,给用户使用数组带来很大的方便,尤其是在使用多维数组的情况下,可以方便的查看多维数组的一些信息。如表2.5所示,列出了几个常用的函数。
函数名 功能
ndims (P) 返回数组P的维数
[m,n,…]=size(P) 返回数组P各维的大小
m=size(P,x) 返回数组P某一维的大小
length(P) 返回数组P的行数或列数的最大值
max(size(P)) 返回数组P的行数或列数的最大值,与length(P)的功能相同

【例2.18】以三维数组A为例,查看矩阵的维数、各维大小以及所有维中最大长度。
&gt;&gt; A=rand(4,5,2) %生成三维均匀分布的随机数组A
①使用ndims函数查看数组A维数,在命令窗口中输入:
&gt;&gt; ndims(A)
返回数组A的维数显示如下:
ans = 3
②使用size函数查看数组A中各维的大小,在命令窗口中输入:
&gt;&gt; size(A) %查看数组A中各维的大小
返回数组A中各维的大小显示如下:
ans = 4 5 2
③使用length函数查看数组A各维中的最大长度,在命令窗口中输入:
&gt;&gt; length(A)
返回数组A各维中的最大长度显示如下:
ans = 5

作者:德特数据
联系方式:[email protected]

以上是关于Prometheus-PQL的主要内容,如果未能解决你的问题,请参考以下文章