常用PromQL语句

2024-06-10 08:20
文章标签 常用 语句 promql

本文主要是介绍常用PromQL语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

常用PromQL语句

    • 1. 查询CPU使用率:
    • 2. 查询内存使用率:
    • 3. 查询磁盘使用率:
    • 4. 查询网络带宽使用率:
    • 5. 查询数据库连接数:
    • 6. 查询HTTP请求响应时间:
    • 7. 查询日志错误数量:
    • 8. 查询系统负载:
    • 9. 查询磁盘I/O使用率:
    • 10. 查询网络流量:
    • 11. 查询数据库慢查询数量:
    • 12. 查询HTTP请求错误率:

以下是一些在运维监控中可能会用到的PromQL语句:

1. 查询CPU使用率:

100 - (avg by(instance) (irate(node_cpu_seconds_total{mode="idle"}[5m])) * 100)

这个语句用于计算每个实例的CPU使用率。它首先获取每个实例的CPU空闲时间,然后计算5分钟内的平均空闲时间速率,最后用100减去空闲时间速率乘以100得到CPU使用率。

2. 查询内存使用率:

(node_memory_MemTotal_bytes - node_memory_MemAvailable_bytes) / node_memory_MemTotal_bytes * 100

这个语句用于计算内存使用率。它首先获取总内存和可用内存,然后用总内存减去可用内存得到已使用的内存量,最后将已使用的内存量除以总内存并乘以100得到内存使用率。

3. 查询磁盘使用率:

(node_filesystem_size_bytes{fstype!~"tmpfs|overlay"} - node_filesystem_avail_bytes{fstype!~"tmpfs|overlay"}) / node_filesystem_size_bytes{fstype!~"tmpfs|overlay"} * 100

这个语句用于计算磁盘使用率。它首先获取非临时文件系统(tmpfs和overlay)的总大小和可用大小,然后用总大小减去可用大小得到已使用的磁盘空间量,最后将已使用的磁盘空间量除以总大小并乘以100得到磁盘使用率。

4. 查询网络带宽使用率:

sum(rate(node_network_receive_bytes_total[5m])) / sum(rate(node_network_transmit_bytes_total[5m])) * 100

这个语句用于计算网络带宽使用率。它首先获取5分钟内接收和发送的字节数,然后计算接收和发送速率,最后将接收速率除以发送速率并乘以100得到网络带宽使用率。

5. 查询数据库连接数:

sum(rate(node_database_connections{state="active"}[5m]))

这个语句用于计算数据库的活动连接数。它首先获取5分钟内活动连接的数量,然后计算速率,最后得到活动连接数。

6. 查询HTTP请求响应时间:

histogram_quantile(0.95, sum(rate(http_request_duration_seconds_bucket[5m])) by (le)) / 1000

这个语句用于计算HTTP请求的95%分位数响应时间。它首先获取5分钟内每个响应时间的桶中的请求数量,然后计算速率,最后得到95%分位数响应时间。

7. 查询日志错误数量:

sum(rate(log_messages_total{level="error"}[5m]))

这个语句用于计算5分钟内的错误日志数量。它首先获取5分钟内错误级别的日志数量,然后计算速率,最后得到错误日志数量。

8. 查询系统负载:

node_load1 / count(count without (cpu, mode) (node_cpu_seconds_total{mode="idle"}))

这个语句用于计算系统负载。它首先获取CPU空闲时间,然后用总CPU数量除以空闲CPU数量得到系统负载。

9. 查询磁盘I/O使用率:

sum(rate(node_disk_io_time_seconds_total[5m])) / sum(rate(node_disk_io_time_weighted_seconds_total[5m])) * 100

这个语句用于计算磁盘I/O使用率。它首先获取5分钟内的磁盘I/O时间和加权时间,然后计算速率,最后将I/O时间速率除以加权时间速率并乘以100得到磁盘I/O使用率。

10. 查询网络流量:

sum(rate(node_network_receive_bytes_total[5m])) + sum(rate(node_network_transmit_bytes_total[5m]))

这个语句用于计算5分钟内的网络流量。它首先获取接收和发送的字节数,然后计算速率,最后将接收速率和发送速率相加得到网络流量。

11. 查询数据库慢查询数量:

sum(rate(node_database_slow_queries_total[5m]))

这个语句用于计算5分钟内的慢查询数量。它首先获取5分钟内慢查询的数量,然后计算速率,最后得到慢查询数量。

12. 查询HTTP请求错误率:

sum(rate(http_requests_total{status_code=~"5.."}[5m])) / sum(rate(http_requests_total[5m])) * 100

这个语句用于计算HTTP请求的错误率。它首先获取5分钟内状态码为5xx的请求数量和总请求数量,然后计算速率,最后将错误请求速率除以总请求速率并乘以100得到错误率。

这篇关于常用PromQL语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047639

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

java常用面试题-基础知识分享

什么是Java? Java是一种高级编程语言,旨在提供跨平台的解决方案。它是一种面向对象的语言,具有简单、结构化、可移植、可靠、安全等特点。 Java的主要特点是什么? Java的主要特点包括: 简单性:Java的语法相对简单,易于学习和使用。面向对象:Java是一种完全面向对象的语言,支持封装、继承和多态。跨平台性:Java的程序可以在不同的操作系统上运行,称为"Write once,

nginx介绍及常用功能

什么是nginx nginx跟Apache一样,是一个web服务器(网站服务器),通过HTTP协议提供各种网络服务。 Apache:重量级的,不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这些都决定了Apache不可能成为高性能WEB服务器  nginx: