openGauss分析查询语句运行状态

网友投稿 854 2022-10-26

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

openGauss分析查询语句运行状态

问题现象

系统中部分查询语句运行时间过长,通过分析查询语句的运行状态可以确认哪些语句 正在运行,哪些语句被阻塞

处理办法

步骤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;查询结果中包含了当前被阻塞的查询语句,该查询语句所请求的锁资源可能被其他会 话持有,正在等待持有会话释放锁资源.

上一篇:华为GaussDB A PGXC_WLM_WORKLOAD_RECORDS
下一篇:不忘初心,恪守信条:微盟经历的从删库到跑路的数据灾难
相关文章

 发表评论

暂时没有评论,来抢沙发吧~