openGauss学习笔记-220 openGauss性能调优-确定性能调优范围-查询最耗性能的SQL

文章目录

    • [openGauss学习笔记-220 openGauss性能调优-确定性能调优范围-查询最耗性能的SQL](#openGauss学习笔记-220 openGauss性能调优-确定性能调优范围-查询最耗性能的SQL)
      • [220.1 操作步骤](#220.1 操作步骤)

openGauss学习笔记-220 openGauss性能调优-确定性能调优范围-查询最耗性能的SQL

系统中有些SQL语句运行了很长时间还没有结束,这些语句会消耗很多的系统性能,请根据本节内容查询长时间运行的SQL语句。

220.1 操作步骤

1、以操作系统用户omm登录数据库节点。

2、使用如下命令连接数据库。

css 复制代码
gsql -d postgres -p 8000

postgres为需要连接的数据库名称,8000为数据库节点的端口号。

连接成功后,系统显示类似如下信息:

python 复制代码
gsql ((openGauss 1.0 build 290d125f) compiled at 2020-05-08 02:59:43 commit 2143 last mr 131
Non-SSL connection (SSL connection is recommended when requiring high-security)
Type "help" for help.

openGauss=# 

3、查询系统中长时间运行的查询语句。

sql 复制代码
SELECT current_timestamp - query_start AS runtime, datname, usename, query FROM pg_stat_activity where state != 'idle' ORDER BY 1 desc;

查询后会按执行时间从长到短顺序返回查询语句列表,第一条结果就是当前系统中执行时间最长的查询语句。返回结果中包含了系统调用的SQL语句和用户执行SQL语句,请根据实际找到用户执行时间长的语句。

若当前系统较为繁忙,可以通过限制current_timestamp - query_start大于某一阈值来查看执行时间超过此阈值的查询语句。

sql 复制代码
SELECT query FROM pg_stat_activity WHERE current_timestamp - query_start > interval '1 days';

4、设置参数track_activities为on。

vbnet 复制代码
SET track_activities = on;

当此参数为on时,数据库系统才会收集当前活动查询的运行信息。

5、查看正在运行的查询语句。

以查看视图pg_stat_activity为例:

sql 复制代码
SELECT datname, usename, state FROM pg_stat_activity;
 datname  | usename | state  |
----------+---------+--------+
 postgres |   omm   | idle   |
 postgres |   omm   | active |
(2 rows)

如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。

如果仅需要查看非空闲的查询语句,则使用如下命令查看:

sql 复制代码
SELECT datname, usename, state FROM pg_stat_activity WHERE state != 'idle';

6、分析长时间运行的查询语句状态。

  • 若查询语句处于正常状态,则等待其执行完毕。

  • 若查询语句阻塞,则通过如下命令查看当前处于阻塞状态的查询语句:

    sql 复制代码
    SELECT datname, usename, state, query FROM pg_stat_activity WHERE waiting = true;

    查询结果中包含了当前被阻塞的查询语句,该查询语句所请求的锁资源可能被其他会话持有,正在等待持有会话释放锁资源。

    说明:

    只有当查询阻塞在系统内部锁资源时,waiting字段才显示为true。尽管等待锁资源是数据库系统最常见的阻塞行为,但是在某些场景下查询也会阻塞在等待其他系统资源上,例如写文件、定时器等。但是这种情况的查询阻塞,不会在视图pg_stat_activity中体现。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

相关推荐
+VX:Fegn08955 分钟前
计算机毕业设计|基于springboot + vue图书管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
杨云龙UP1 小时前
MySQL 8.0.x InnoDB 写入链路优化:Redo Log 与 Buffer Pool 扩容与缓冲区调优实战记录-20251029
linux·运维·数据库·sql·mysql
黄俊懿2 小时前
【深入理解SpringCloud微服务】Seata(AT模式)源码解析——开启全局事务
java·数据库·spring·spring cloud·微服务·架构·架构师
我命由我123452 小时前
python-dotenv - python-dotenv 快速上手
服务器·开发语言·数据库·后端·python·学习·学习方法
繁星蓝雨2 小时前
Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码
开发语言·数据库·qt
Jerry.张蒙3 小时前
SAP业财一体化实现的“隐形桥梁”-价值串
大数据·数据库·人工智能·学习·区块链·aigc·运维开发
无名修道院3 小时前
DVWA 靶场搭建:Windows11(phpstudy 搭建)(步骤 + 截图 + 常见问题)
数据库·网络安全·渗透测试·靶场·php·dvwa·phpstudy
CodeAmaz5 小时前
MySQL 事务隔离级别详解
数据库·mysql·事务隔离级别
千寻技术帮5 小时前
10398_基于SSM的教学评价管理系统
数据库·mysql·毕业设计·ssm·教学评价
晨星3345 小时前
使用 IntelliJ IDEA 轻松连接 Java 与 MySQL 8 数据库
java·开发语言·数据库