【云小课】如何初步定位GaussDB(for openGauss)慢SQL

GaussDB数据库 举人 2021-11-16 17:41:37

云小课必用.png

 

 

数据库在日常使用的过程中会产生很多SQL语句,而如果有些SQL语句运行了很长时间还没有结束,这些语句会消耗很多的系统性能。

那么如何查询到有哪些SQL语句影响了系统的运行呢?

学了本节课程后,您就将会掌握初步定位GaussDB(for openGauss)慢SQL的方法。

操作场景

  • 数据库执行SQL语句长时间无响应。
  • 数据库CPU/内存压力一直很大。

操作步骤

1.   使用DAS或者gsql连接实例。

2.   查询系统中长时间运行的查询语句。

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大于某一阈值来查看执行时间超过此阈值的查询语句。

SELECT query FROM pg_stat_activity WHERE current_timestamp - query_start > interval '1 days';

3.   设置参数track_activities为on。

SET track_activities = on;

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

4.   从当前活动会话视图查找问题会话的线程ID。

SELECT datid, pid, state, query FROM pg_stat_activity;

显示类似如下信息,其中pid的值即为该会话的线程ID。

 datid |       pid       | state  | query 
-------+-----------------+--------+------- 
 13205 | 139834762094352 | active | 
 13205 | 139834759993104 | idle   | 
(2 rows)

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

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

SELECT datid, pid, state, query FROM pg_stat_activity WHERE state != 'idle';

5.   分析长时间运行的查询语句状态。

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

         如果是因为SQL执行效率低,建议参考官方文档优化SQL语句。

  • 若查询语句不正常执行,则参考步骤6结束异常会话。

6.   根据线程ID结束会话。

SELECT pg_terminate_backend(139834762094352);

显示类似如下信息,表示结束会话成功。

pg_terminate_backend 
---------------------- 
 t 
(1 row)

显示类似如下信息,表示用户正在尝试结束当前会话,此时仅会重连会话,而不是结束会话。

FATAL:  terminating connection due to administrator command 
FATAL:  terminating connection due to administrator command 
The connection to the server was lost. Attempting reset: Succeeded.

1.png

          gsql客户端使用pg_terminate_backend函数终止本会话后台线程时,客户端不会退出而是自动重连。

 

...全文
370 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复

感谢优质内容,将收录到CSDN官方的社区周刊。往期参考 https://bbs.csdn.net/topics/603335113

通过sql分析的学习,了解什么是sql,以及SQL会引起那些性能问题。清楚sql日志的设置,然后再通过sql分析工具的学习,清楚sql分析的步骤和流程。sql分析工具:mysqldumpslow工具、explain工具、profile工具、Optimizer Trace工具。 提供程中所使用的sql语句。 程内容:第一章:程简介1、程介绍2、程大纲 第二章:sql简介1、sql简介2、sql会引起的问题 第三章:日志的设置1、sql的分析流程2、日志参数理解3、日志参数设置:第1种方式:my.ini文件设置4、日志参数设置:第2种方式:sql脚本设置5、日志参数设置-效果验证 第四章:如何发现sql1、如何发现sql:第1种方式:日志文件2、如何发现sql:第2种方式:mysql库的slow_log表 第五章:sql分析工具1、sql提取-mysqldumpslow工具-使用方法2、sql提取-mysqldumpslow工具-操作实战3、sql的执行计划分析-explain分析-执行计划结果说明4、sql的执行计划分析-explain分析-索引介绍+type类型举例5、sql的资源开销分析-profile分析-分析步骤6、sql的资源开销分析-profile分析-show profile执行阶段说明7、sql的资源开销分析-profile分析-完整列表说明+操作实战8、sql的跟踪分析-Optimizer Trace分析-分析步骤9、sql的跟踪分析-Optimizer Trace表的介绍10、索引失效场景举例 第六章:日志清理1、日志清理

68,600

社区成员

发帖
与我相关
我的任务
社区描述
汇集数据库的爱好者和关注者,大家共同学习、探索、分享数据库前沿知识和技术,像松鼠一样剥开科学的坚果;交流Gauss及其他数据库的使用心得和经验,互助解决问题,共建数据库技术交流圈。
数据库数据仓库 企业社区 北京·海淀区
社区管理员
  • Gauss松鼠会
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

欢迎大家同时关注Gauss松鼠会专家酷哥。

https://www.zhihu.com/people/ku-ge-78-98

试试用AI创作助手写篇文章吧