云数据库 GaussDB-查看系统表:查看和停止正在运行的查询语句

时间:2023-11-01 16:22:10

查看和停止正在运行的查询语句

通过视图PG_STAT_ACTIVITY可以查看正在运行的查询语句。方法如下:

  1. 设置参数track_activities为on。

    1
    SET track_activities = on;

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

  2. 查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的PID为例:

    1
    SELECT datname, usename, state,pid FROM pg_stat_activity;
    12345678
     datname  | usename | state  |       pid----------+---------+--------+----------------- postgres | Ruby    | active | 140298793514752 postgres | Ruby    | active | 140298718004992 postgres | Ruby    | idle   | 140298650908416 postgres | Ruby    | idle   | 140298625742592 postgres | omm | active | 140298575406848(5 rows)

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

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

    1
    SELECT datname, usename, state pid FROM pg_stat_activity WHERE state != 'idle';

  3. 若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID结束会话。

    1
    SELECT PG_TERMINATE_BACKEND(139834759993104);

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

    1234
    PG_TERMINATE_BACKEND---------------------- t(1 row)
    显示类似如下信息,表示用户执行了结束当前会话的操作。
    12
    FATAL:  terminating connection due to administrator commandFATAL:  terminating connection due to administrator command

    gsql客户端使用PG_TERMINATE_BACKEND函数结束当前会话后台线程时,客户端不会退出而是自动重连。即还会返回“The connection to the server was lost. Attempting reset: Succeeded.”

    123
    FATAL:  terminating connection due to administrator commandFATAL:  terminating connection due to administrator commandThe connection to the server was lost. Attempting reset: Succeeded.

support.huaweicloud.com/centralized-devg-v2-opengauss/devg_03_0019.html