MogDBMogDB Stack
生态工具
v3.0
文档目录
文档:v3.0
支持的版本:

分析查询语句运行状态

问题现象

系统中部分查询语句运行时间过长,需要分析查询语句的运行状态。

处理办法

  1. 以操作系统用户omm登录主机。

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

    gsql -d postgres -p 8000

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

  3. 设置参数track_activities为on。

    SET track_activities = on;

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

  4. 查看正在运行的查询语句。以查看视图pg_stat_activity为例。

    SELECT datname, usename, state, query FROM pg_stat_activity;
    datname  | usename | state  | query
    ----------+---------+--------+-------
    mogdb     | omm     | idle   |
    mogdb     | omm     | active |
    (2 rows)

    如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。 如果仅需要查看非空闲的查询语句,则使用如下命令查看。

    SELECT datname, usename, state, query FROM pg_stat_activity WHERE state != 'idle';
  5. 分析查询语句为活跃状态还是阻塞状态。通过如下命令查看当前处于阻塞状态的查询语句。

    SELECT datname, usename, state, query FROM pg_stat_activity WHERE waiting = true;

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

数据库
基于openGauss开源数据库进行定制,推出的企业发行
Kubernetes上的MogDB自动运维系统
关于
云和恩墨社区
MogDB联系我们
管理工具
高可用管理
图形化管理
部署运维工具
Migrate to MogDB解决方案
异构数据库迁移
异构数据同步
兼容性分析
数据一致性校验
文档工具
参数对比