openGauss学习笔记-195 openGauss 数据库运维-常见故障定位案例-分析查询语句运行状态

openGauss学习笔记-195 openGauss 数据库运维-常见故障定位案例-分析查询语句运行状态

195.1 分析查询语句运行状态

195.1.1 问题现象

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

195.1.2 处理办法
  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 
    ----------+---------+--------+-------
    postgres | omm     | idle   | 
    postgres | 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;
    

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

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

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

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

图片

最近更新

  1. TCP协议是安全的吗?

    2024-01-13 17:54:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-13 17:54:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-13 17:54:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-13 17:54:03       18 阅读

热门阅读

  1. android 返回到首页案例

    2024-01-13 17:54:03       34 阅读
  2. Redis面试系列-02

    2024-01-13 17:54:03       31 阅读
  3. how to protect your stomach

    2024-01-13 17:54:03       28 阅读
  4. Gorm 关联关系介绍与基本使用

    2024-01-13 17:54:03       31 阅读
  5. ARM动态Trustzone技术简介

    2024-01-13 17:54:03       35 阅读
  6. HTML常用标签

    2024-01-13 17:54:03       35 阅读
  7. ansible自动化部署(playbook)

    2024-01-13 17:54:03       26 阅读
  8. CAP与BASE理论

    2024-01-13 17:54:03       35 阅读
  9. 华为网络设备安全基线配置指南

    2024-01-13 17:54:03       28 阅读