PromQL基本使用

PromQL介绍

1. 瞬时向量与范围向量查询
2. 常用操作符
3. 常用函数

PromQL(Prometheus Query Language) 是 Prometheus 自己开发的数据查询 DSL 语言,语言表现力
非常丰富,支持条件查询、操作符,并且内建了大量内置函数,供我们针对监控数据的各种维度进行查
询。

瞬时查询与范围查询

目标实例状态:
up

查询指标最新样本(称为瞬时向量):
node_cpu_seconds_total

可以通过附加一组标签来进一步过来这些时间序列:
node_cpu_seconds_total{job="Linux Server"}

查询指标近5分钟内样本(称为范围向量,时间单位 s,m,h,d,w,y):
node_cpu_seconds_total{job="Linux Server"}[5m]
node_cpu_seconds_total{job="Linux Server"}[1h]

常用的操作符与函数使用

在这里插入图片描述

函数:
• irate():计算指标在一定时间间隔内的变化速率
示例:irate(node_cpu_seconds_total{job=“Linux Server”,mode=“system”}[5m])

Prometheus是一个开源的系统监控和警报工具,它支持多种数据采集方式,包括自主的Prometheus采集器、服务端的exporter插件以及第三方的pushgateway等。以下是Prometheus的基本使用方法: 1. 安装和启动Prometheus Prometheus可以在官网上下载二进制文件,也可以使用容器来部署。安装好后,可以使用命令行启动Prometheus: ``` ./prometheus --config.file=prometheus.yml ``` 其中,prometheus.yml是一个配置文件,用于指定数据采集器和数据存储方式等。 2. 配置数据采集器 Prometheus支持多种数据采集器,包括自主的Prometheus采集器、服务端的exporter插件以及第三方的pushgateway等。可以在prometheus.yml文件中配置数据采集器: ``` scrape_configs: - job_name: 'prometheus' static_configs: - targets: ['localhost:9090'] - job_name: 'node_exporter' static_configs: - targets: ['localhost:9100'] ``` 以上配置实现了对本地的Prometheus采集器和node_exporter采集器的监控。 3. 查询数据 Prometheus提供了一个查询语言PromQL,用于查询和分析采集到的数据。可以使用Prometheus的WebUI或API查询数据: ``` http://localhost:9090/graph?g0.range_input=1h&g0.expr=node_cpu{mode="idle"}&g0.tab=0 ``` 以上查询语句查询了最近1小时内所有节点的空闲CPU时间。 4. 设置警报规则 Prometheus支持设置警报规则,当某个监控指标超过或低于特定阈值时,会触发警报。可以在prometheus.yml文件中配置警报规则: ``` rules: - alert: HighCPUUsage expr: node_cpu{mode="user"} > 90 for: 5m labels: severity: warning annotations: summary: "High CPU usage detected" description: "CPU usage for {{ $labels.instance }} is {{ $value }}%" ``` 以上规则表示,当某个节点的用户CPU占用率超过90%持续5分钟时,会触发一个警报,并在警报信息中包含节点名称和CPU占用率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值