数据库在日常使用的过程中会产生很多SQL语句,而如果有些SQL语句运行了很长时间还没有结束,这些语句会消耗很多的系统性能。
那么如何查询到有哪些SQL语句影响了系统的运行呢?
学了本节课程后,您就将会掌握初步定位GaussDB(for openGauss)慢SQL的方法。
操作场景
- 数据库执行SQL语句长时间无响应。
- 数据库CPU/内存压力一直很大。
操作步骤
-
使用DAS或者gsql连接实例。
-
查询系统中长时间运行的查询语句。
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 da